QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1175

主题

4

听众

2803

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |正序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:& T6 l( t" ~& i; s
clear all
: k, u3 R  o. }8 Z1 m) k/ N8 M2 p%图论最短路问题的Dijkstra算法* C9 S/ Q9 p, A) K
%邻接矩阵(点与点的关系)# V" K) ^" e" u: z& d; ^+ }& P
w=[0,2,4,inf,inf,inf,inf;  * \! }. X- u* G+ p( N0 A
   2,0,inf,3,3,1,inf;
* \; U1 e& N9 ]; F/ p   4,inf,0,2,3,1,inf;                     
6 ?" u2 t2 ]- C7 ^5 H: b   inf,3,2,0,inf,inf,1;                    : ^  m5 A' y8 Q  i' t2 p/ }: x
   inf,3,3,inf,0,inf,3;
7 f- ?2 O: j" d# a% l$ q: I   inf,1,1,inf,inf,0,4;
4 K' f5 p) W* W5 B0 p   inf,inf,inf,1,3,4,0];
. ^6 I$ ?. u$ ]" B9 h; M- Yn=size(w,1);%记录图中点数- p. X0 M) h8 T; ]4 C: h! |

# \- c. L7 q! B; g1 _# bfor i=1:n
9 c6 j$ F4 {( K, Q4 R, I4 T    l(i)=w(1,i); %为l(v)赋初值. W) q& L4 V7 R! V" F1 ^* [
    z(i)=1;      %为z(v)赋初值1* `8 T& _" N" T4 p0 ]6 S- O3 Q
end
/ O  B( D8 @' L6 u8 a: {7 m7 d) X" |" z# b2 R' Q; M6 {
s=[];            %s集合' N- f" E0 h) T
s(1)=1;          %s集合的第1个元素为起点
+ J: d! F5 G: f& nu=s(1);
8 v- l5 I* o* X4 G1 Z+ z; |; lk=1;             %k记录集合s中点的数量  u5 H; R3 S+ K) b0 Y4 t+ \1 y
. l& H; T, S* _
while k<n       %当集合s未包含所有元素的时候执行循环
: b$ c2 \) h! m4 |    for i=1:n    %更新一遍l(v),z(v)
$ {# K# ]1 H; c4 n+ w        if l(i)>l(u)+w(u,i)$ @4 x' v: z3 J  D7 x
            l(i)=l(u)+w(u,i);
* U. R/ v0 q$ F1 w5 C4 B. ?; b            z(i)=u;
, o  Q& x) n' J3 c; O        end
4 b5 R0 J; V0 v% X  A) a7 j    end
' N1 s% b7 T' m
' g0 [* s! m' N2 V    %找l(i)中最小的v加入s集合7 B6 F; H3 E& k  C& v% [$ H
    ll=l;
5 f3 }5 c" w6 Z/ J# A5 w    for i=1:n
2 B9 i; Q2 C& s9 A6 W. B5 o1 J; P        for j=1:k$ l2 c* j7 S! N* |  b, N  C3 u
            if i==s(j)
+ ]; d3 `4 P2 s                ll(i)=inf; %去除掉已经在s集合中的点9 r! h% A; A& M- o+ {: x
            end 6 u, B) s' C' O6 u) m4 [
        end
- v+ Q# L* d9 i3 E. m    end* Q6 z7 p# T1 g5 ~# [6 E
    [lv,v]=min(ll); %求最小的l(v)
" ^! X- i* O- j. ]. H    s(k+1)=v;       %加入集合s0 \- B' o5 j, D. Z% a
    u=v;
# o( a0 X4 {- p$ _    k=k+1;
. M7 S/ ^; e+ I/ \7 Yend
$ m+ Z; F) f3 m1 T% P1 V2 Y$ E" v+ _/ b; r
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)7 b# M: N: V$ z; k/ y; T5 y

" t  m% Q& O$ O4 V5 g3 y解释:
% ^; h# Q+ _0 p" H. u" `) O8 f0 M  H) {, }1 u% i
1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。( J7 {" f  `! z: \! Z  g& J
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。$ s1 G" F% |0 ^# a( {
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。+ i* l3 D# T/ D3 F3 _9 u5 `1 N
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。3 o  V6 l4 L4 Y2 {8 Y
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。  a+ W. d1 q- C+ F) f

1 u! p2 ]; |: b! q注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。5 i/ M5 U( V8 }/ X1 a  @$ d6 M
! `# t# d- l8 C8 C

9 D0 L5 P, d6 I' w

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-7-6 07:25 , Processed in 0.508068 second(s), 55 queries .

回顶部