QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1184

主题

4

听众

2916

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
7 R0 G9 Y. y# }clear all9 c! I8 G/ t4 d% r. d4 c
%图论最短路问题的Dijkstra算法- _0 y6 n" k# u& x* n
%邻接矩阵(点与点的关系)
: P* _  o/ g6 p4 Iw=[0,2,4,inf,inf,inf,inf;  
: l" i- x, U8 I# X   2,0,inf,3,3,1,inf;
4 w* f5 w8 v, u7 j   4,inf,0,2,3,1,inf;                      6 c" r8 n) s  p- a
   inf,3,2,0,inf,inf,1;                    " x3 o8 H7 G* a( h8 t/ ]/ v! V
   inf,3,3,inf,0,inf,3;, u9 x' p: E( |
   inf,1,1,inf,inf,0,4;0 s6 x& [/ B! Z+ |1 `
   inf,inf,inf,1,3,4,0];' D: {0 \' h+ R+ K  Z) C
n=size(w,1);%记录图中点数
* p: A0 c; z  g6 V3 Q
  I5 j( P  b3 W% b, x+ pfor i=1:n
( P9 ~" e0 X4 k2 Y    l(i)=w(1,i); %为l(v)赋初值
( f- T2 ^0 I' f7 h    z(i)=1;      %为z(v)赋初值1
' Q% N/ W$ b2 |4 bend
/ C, V& M) q' f' D* m8 g
" Y9 }$ w& M9 L; O/ P: |s=[];            %s集合
+ |: ?- g: Y& b2 As(1)=1;          %s集合的第1个元素为起点
- A: I3 }; ~3 l- q! Ju=s(1);
" ^+ Y: d3 ]  K3 U: d, }k=1;             %k记录集合s中点的数量
8 v9 w, [) B/ m1 o0 L) T, j& ]; C- m9 k0 Y+ a5 e1 G
while k<n       %当集合s未包含所有元素的时候执行循环
4 n0 `4 X1 X7 f+ B; x    for i=1:n    %更新一遍l(v),z(v)$ T; \2 V+ {' [: Y+ h) p
        if l(i)>l(u)+w(u,i)# f7 b: Z5 o( i, Z
            l(i)=l(u)+w(u,i);
5 D; U& T+ u: a6 I0 M* E; `& O7 ^            z(i)=u;
: Y9 H: Z# {- Y  e$ e        end
. G$ q5 ]& W3 f3 P! ?* @: U! s) a" B    end
9 @: _/ b1 H  l- N3 l9 j' y& _4 k4 U& w: z! a1 X2 d) M& P
    %找l(i)中最小的v加入s集合
& r; s9 f# n5 M9 x    ll=l;
9 \9 K5 u8 L. y+ N$ ^4 O    for i=1:n% c5 u$ h. f2 U, S; H& U
        for j=1:k
! ]$ S, C+ p5 x9 w( G            if i==s(j)' Z1 L' @8 j/ m! O5 Q
                ll(i)=inf; %去除掉已经在s集合中的点4 S0 D; |1 l( Q& M! z2 E
            end
' B- I6 h5 i6 d+ I        end
+ D( T/ _5 i5 k1 {% T: J: P    end
# E4 H8 h) ?' W' ^6 O% ]5 P    [lv,v]=min(ll); %求最小的l(v)
. B: r! v2 ^1 L    s(k+1)=v;       %加入集合s+ h: h$ r, Q& r. i* m- h+ [3 C
    u=v;) P, R% K( D0 J2 T0 ?! _; y
    k=k+1;  u4 u) R8 F/ l
end
$ C' p2 @/ S/ s
. Q$ t1 Q; T" F0 G3 p' rfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
7 E  p9 w7 F4 N1 [) x- Q$ o' G7 Z# v
解释:% E/ `- `  y1 a6 Y2 f1 G
7 @* a) r! y. t+ K) k5 e
1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
2 f9 Z8 i3 M: z+ v- V& Q2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。. f% ?! ^$ K7 z' ?1 b, S$ Q* Z$ g- a
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
- ?5 K7 M% i2 r$ L* |4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。" n) B2 C- ?8 G. ^
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。$ z* ]& l. J& j1 C) ?% U

* s/ T  m+ b2 Q注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
/ F& d, Q1 l: K4 D( k* a  ^6 a+ Z  V4 M+ b
: H# F% d3 w& g: M$ Z

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-12-28 15:25 , Processed in 0.428885 second(s), 55 queries .

回顶部