QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1931|回复: 0
打印 上一主题 下一主题

图中最短路径解决方法 Dijkstra

[复制链接]
字体大小: 正常 放大

1175

主题

4

听众

2849

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
  v6 |2 X) E0 t# E1 {) O" Pclear all. h5 c- G; ?2 E: }9 ~* h
%图论最短路问题的Dijkstra算法/ ?$ z, ^4 i: w
%邻接矩阵(点与点的关系)  N# {6 c, W3 f$ j4 c2 T
w=[0,2,4,inf,inf,inf,inf;  2 u. j- B9 T2 i1 x
   2,0,inf,3,3,1,inf;
/ ]: D4 h) E7 s0 I   4,inf,0,2,3,1,inf;                     
; U( X- y) {! m   inf,3,2,0,inf,inf,1;                    
, L! K2 c# H& G' E/ Z   inf,3,3,inf,0,inf,3;, I3 y- `4 ^, K$ P; J
   inf,1,1,inf,inf,0,4;, o$ d  M  l8 H4 n2 q$ Q/ r- G
   inf,inf,inf,1,3,4,0];
- `/ Y& ^( R( f: k; L) On=size(w,1);%记录图中点数
- I# n; b/ S' N; e/ [  s' P( I0 b5 `+ w& f9 V; Z& v/ _+ D4 ?% R0 H: r
for i=1:n- D3 @4 t! O( n2 @
    l(i)=w(1,i); %为l(v)赋初值
+ a9 X& o: Y% |    z(i)=1;      %为z(v)赋初值1
. W) O2 u0 g! W! L' G9 Q+ Kend
3 ?1 R( M! i, p& H2 s1 ]2 A6 i3 D4 ?$ h* E
s=[];            %s集合
4 n  V$ }7 h5 m+ J1 g& e- R  F+ \s(1)=1;          %s集合的第1个元素为起点, v, s+ x! M. n, Z
u=s(1);
. t2 C; }: S( A; Ek=1;             %k记录集合s中点的数量" g. Y4 M  p9 V/ w8 M9 Q+ o* _
: i+ e; S& k$ [8 Z6 Q  C- `9 ]7 _
while k<n       %当集合s未包含所有元素的时候执行循环
6 V% z# B. G* h: N% q; r' [( r    for i=1:n    %更新一遍l(v),z(v)2 p$ Z& g1 U$ A; H; J
        if l(i)>l(u)+w(u,i): m: d) S. w8 d( i
            l(i)=l(u)+w(u,i);
& I+ s' {" {- W7 q4 c            z(i)=u;
3 S5 e# J1 ?6 o1 A8 ?4 Z; g& n        end. j& w7 B6 \2 _. S! w& a
    end
  M3 m! \) O* l) ?# P2 N; a- b1 M
$ c& [( o  x; v) Q! e& ?4 y6 u    %找l(i)中最小的v加入s集合' C2 V% p7 [1 ]: \
    ll=l;# q* U$ F. e3 y4 j- B' d
    for i=1:n: _; V( j" V! }6 l& z/ V
        for j=1:k9 g4 y. Z+ Q" C( @- C7 [# X; Z1 z
            if i==s(j)0 p, {! Y4 [6 n. k7 W* r) _, T
                ll(i)=inf; %去除掉已经在s集合中的点
* M  k- E" U  N  e            end
) D7 c  O; L# o$ E& i% \0 [        end
3 j5 P3 |8 m- q* w0 ?1 l    end
* c  P' Z. G$ \    [lv,v]=min(ll); %求最小的l(v)
5 R- k6 o# e# m# ?. \: Q0 l' \* f    s(k+1)=v;       %加入集合s3 O3 V5 M# G! [3 l- p
    u=v;. f) W! h2 ?; I
    k=k+1;
  M  V7 c# w4 S* zend+ n2 h; R9 l% a! @" G

9 X; j0 d- q1 K7 U$ N, I/ j5 pfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
  ], N( u  P, L7 o5 ~2 p5 j) G0 |
, V1 r  j9 |2 F解释:" j0 Y9 `4 ~0 X7 |

0 s  B$ \+ u; }& W: h  _) l8 e1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
. T& |. u8 `# \# {4 D. @( p2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
  K8 C' R% u5 D9 ]0 D3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。* U8 j4 C3 Z& [& ]4 ~
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。9 J/ N7 A/ o  p3 S- t  l. J& F1 j, a
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
! a; a) F$ _/ f' e  D$ m/ _4 ^# X% e. T' _
注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。- n5 |- u- ~+ E9 n- r' g$ `; V

3 P2 P4 E; C* C' F; v! X1 I3 ]# z) e. i/ ?* W  V

Dijkstra.m

913 Bytes, 下载次数: 0, 下载积分: 体力 -2 点

售价: 1 点体力  [记录]  [购买]

zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2025-8-4 05:26 , Processed in 0.411448 second(s), 54 queries .

回顶部