24小时热门版块排行榜    

CyRhmU.jpeg
查看: 1859  |  回复: 6

木之枝

铜虫 (小有名气)

[求助] 图论与两点间最短路的Warshall-Floyd算法

《图论算法及其MATLAB实现》王海英这本书中 提到关于求两点间最短路的Warshall-Floyd算法(类似还有Dijkstra算法及改进的Dijkstra算法)的程序如下:
CODE:
function[P u]=f_path(W)
% W表示权值矩阵
% P表示最短路
% u表示最短路的权和

%初始化,步骤1
n=length(W)
U=W
m=1;
%步骤2
while m<=n           %判断是否满足停止条件
      for i=1:n
          for j=1:n
              if U(i,j)>U(i,m)+U(m,j)
                  U(i,j)=U(i,m)+U(m,j);   %更新dij
              end
          end
      end
      m=m+1;
end
u=U(1,n);
%输出最短路的顶点
P1=zeros(1,n);
k=1;
P1(k)=n;
V=ones(1,n)*inf;
kk=n;
while kk~=1
    for i=1:n
        V(1,i)=U(1,kk)-W(i,kk);
        if V(1,i)==U(1,i)
            P1(k+1)=i;
            kk=i;
            k=k+1;
        end
    end
end
k=1;
wrow=find(P1~=0);
for j=length(wrow):(-1):1
    P(k)=P1(wrow(j));
    k=k+1;
end
P;

结果我用.m文件复制粘贴到运行窗口(或点击直接运行)后,还没有输入W的矩阵就显示为:??? function[P u]=f_path(W)
    |
Error: Function definitions are not permitted at the prompt or in scripts.
这是为什么呢!!!
本人MATLAB初学,忘大家多多指出一些问题,谢谢大家,感激不尽!!!

[ Last edited by jjdg on 2013-10-9 at 09:37 ]
回复此楼

» 猜你喜欢

» 本主题相关价值贴推荐,对您同样有帮助:

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★ ★ ★ ★ ★ ★ ★ ★
感谢参与,应助指数 +1
木之枝: 金币+8, ★★★★★最佳答案, 谢谢虫友!!! 2013-10-09 21:50:25
xzhdty: 金币+1, 谢谢参与 2013-10-11 07:24:55
这是个function,你不能直接在运行窗口运行,
新建一个m文件,名字必须叫f_path.m,这是matlab的规定,函数必须存在同名文件,
然后先按一下F5,弹出的对话框选择"change folder path"(类似的这种,就是改变当前路径),
然后在命令窗口(command window),自己定一个W权值矩阵,作为输入调用[p,u] = f_path(W)就会调用函数计算出p和u
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
2楼2013-10-09 20:05:18
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

木之枝

铜虫 (小有名气)

引用回帖:
2楼: Originally posted by libralibra at 2013-10-09 20:05:18
这是个function,你不能直接在运行窗口运行,
新建一个m文件,名字必须叫f_path.m,这是matlab的规定,函数必须存在同名文件,
然后先按一下F5,弹出的对话框选择"change folder path"(类似的这种,就是改变当前 ...

之前文件名存的是f-path,现改成f-path.m了。F5运行弹出的对话框选择change directory。
结果是 ??? Undefined variable "f_path" or class "f_path.m".
怎么改啊?
3楼2013-10-09 21:45:33
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

引用回帖:
3楼: Originally posted by 木之枝 at 2013-10-09 21:45:33
之前文件名存的是f-path,现改成f-path.m了。F5运行弹出的对话框选择change directory。
结果是 ??? Undefined variable "f_path" or class "f_path.m".
怎么改啊?...

注意看function后面的函数名跟我的回复,是f_path.m,不是f-path.m
matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
4楼2013-10-10 17:52:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

木之枝

铜虫 (小有名气)

引用回帖:
4楼: Originally posted by libralibra at 2013-10-10 17:52:26
注意看function后面的函数名跟我的回复,是f_path.m,不是f-path.m...

我是存的f_path.m,手误打错了。。可能是程序有什么问题,只是我找不出来啊
5楼2013-10-11 08:51:47
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

libralibra

至尊木虫 (著名写手)

骠骑将军

【答案】应助回帖

★ ★
木之枝: 金币+2, ★★★★★最佳答案, 谢谢。文件名没什么问题。主要是我的原编程中前3行是clear all close all clc 2013-10-11 21:30:22
引用回帖:
5楼: Originally posted by 木之枝 at 2013-10-11 08:51:47
我是存的f_path.m,手误打错了。。可能是程序有什么问题,只是我找不出来啊...

Undefined variable "f_path" or class "f_path.m".
绝对是文件名和路径的问题,这个报错看不出来程序有任何问题

» 本帖已获得的红花(最新10朵)

matlab/VB/python/c++/Java写程序请发QQ邮件:790404545@qq.com
6楼2013-10-11 16:18:45
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

木之枝

铜虫 (小有名气)

送红花一朵
引用回帖:
6楼: Originally posted by libralibra at 2013-10-11 16:18:45
Undefined variable "f_path" or class "f_path.m".
绝对是文件名和路径的问题,这个报错看不出来程序有任何问题...

把前3行除掉就没问题了。谢谢你
7楼2013-10-11 21:31:11
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
相关版块跳转 我要订阅楼主 木之枝 的主题更新
信息提示
请填处理意见