matlab程序,下面的程序如果输入的一个较小的矩阵就可以计算,但是如果矩阵过大就报错,这是为什么 5

function[distancepath]=dijk(w,st,e)%DIJKSummaryofthisfunctiongoeshere%W权值矩阵st搜索的起点e搜索... function [ distance path] = dijk(w,st,e)
%DIJK Summary of this function goes here
% W 权值矩阵 st 搜索的起点 e 搜索的终点
n=length(w); %节点数
D = w(st,:);
visit=ones(1:n);
visit(st)=0;
parent = zeros(1,n);%记录每个节点的上一个节点
path =[];
for i=1:n-1
temp = [];
%从起点出发,找最短距离的下一个点,每次不会重复原来的轨迹,设置visit判断节点是否访问
for j=1:n
if visit(j)
temp =[temp D(j)];

else
temp =[temp inf];
end

end
end
[value,index] = min(temp);
visit(index) = 0;

%更新 如果经过index节点,从起点到每个节点的路径长度更小,则更新,记录前趋节点,方便后面回溯循迹
for k=1:n
if D(k)>D(index)+w(index,k)
D(k) = D(index)+w(index,k);
parent(k) = index;
end
end
distance = D(e);%最短距离
%回溯法 从尾部往前寻找搜索路径
t = e;
while t~=st && t>0 path =[t,path];
p=parent(t);t=p;
end
path =[st,path];%最短路径
end
Error using ==> ones
Maximum variable size allowed by the program is exceeded.
Error in ==> dijk at 7
visit=ones(1:n);
这就是报错的语句
展开
 我来答
电灯剑客
科技发烧友

2015-08-05 · 智能家居/数码/手机/智能家电产品都懂点
知道大有可为答主
回答量:1.2万
采纳率:83%
帮助的人:4942万
展开全部
你把ones(1:n)改成ones(1,n)试试
我没细看代码,不过很显然ones(1:n)这样的n维数组是不对的
--
2022-12-05 广告
图形化编程简单理解为用积木块形式编程,scratch和python也是其中的一种,属于入门级编程,以其简单生动的画面获得无数学生的喜爱,深圳市创客火科技有限公司是一家做教育无人机的公司,旗下有编程无人机,积木无人机及室内外编队,每款飞机含有... 点击进入详情页
本回答由--提供
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式