4个回答
展开全部
提供一个方法:
n=10;%可以改成你想要的数
A=zeros(n);
index=randperm(n);%生成随机排列是关键
A((n)*(0:n-1)+index)=1
因为是随机序列,所以每次都不一样,一个结果:
A =
0 0 0 0 0 1 0 0 0 0
0 0 0 0 1 0 0 0 0 0
0 0 0 1 0 0 0 0 0 0
0 0 0 0 0 0 0 0 1 0
1 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0
0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 1 0 0
0 0 0 0 0 0 1 0 0 0
0 0 0 0 0 0 0 0 0 1
用循环实在没必要,n较大的时候严重影响计算速度,不过好编程:
for k=1:n
A(index(k),k)=1
end
效果是一样的,不再啰嗦了。
n=10;%可以改成你想要的数
A=zeros(n);
index=randperm(n);%生成随机排列是关键
A((n)*(0:n-1)+index)=1
因为是随机序列,所以每次都不一样,一个结果:
A =
0 0 0 0 0 1 0 0 0 0
0 0 0 0 1 0 0 0 0 0
0 0 0 1 0 0 0 0 0 0
0 0 0 0 0 0 0 0 1 0
1 0 0 0 0 0 0 0 0 0
0 0 1 0 0 0 0 0 0 0
0 1 0 0 0 0 0 0 0 0
0 0 0 0 0 0 0 1 0 0
0 0 0 0 0 0 1 0 0 0
0 0 0 0 0 0 0 0 0 1
用循环实在没必要,n较大的时候严重影响计算速度,不过好编程:
for k=1:n
A(index(k),k)=1
end
效果是一样的,不再啰嗦了。
展开全部
提供一个方法:
n=10;%可以改成你想要的数
A=zeros(n);
index=randperm(n);%生成随机排列是关键
A((n)*(0:n-1)+index)=1
因为是随机序列,所以每次都不一样,一个结果:
A
=
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
1
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
1
用循环实在没必要,n较大的时候严重影响计算速度,不过好编程:
for
k=1:n
A(index(k),k)=1
end
效果是一样的,不再啰嗦了。
n=10;%可以改成你想要的数
A=zeros(n);
index=randperm(n);%生成随机排列是关键
A((n)*(0:n-1)+index)=1
因为是随机序列,所以每次都不一样,一个结果:
A
=
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
1
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
1
0
0
0
0
0
0
0
0
0
0
0
0
1
用循环实在没必要,n较大的时候严重影响计算速度,不过好编程:
for
k=1:n
A(index(k),k)=1
end
效果是一样的,不再啰嗦了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
m=10;%行数
n=15;%列数
a=zeros(m,n);
%生成全零矩阵
b=randi(m,[1
n]);
%生成n个从1到m的随机整数
ind=sub2ind([m,n],b,1:n);%形成位置
a(ind)=1;%将对应位置变为1
n=15;%列数
a=zeros(m,n);
%生成全零矩阵
b=randi(m,[1
n]);
%生成n个从1到m的随机整数
ind=sub2ind([m,n],b,1:n);%形成位置
a(ind)=1;%将对应位置变为1
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
没别的要求?
eye(4,4)-----4*4单位矩阵
eye(4,4)-----4*4单位矩阵
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询