QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:2 T9 b+ N; a, q& q% t# o9 g2 E
clear all
0 [9 R1 S3 @8 F/ K  X7 K4 c%图论最短路问题的Dijkstra算法# o3 ^. t' c  C7 A9 {0 w
%邻接矩阵(点与点的关系)1 `" b+ o% ]- T* w: ^# t1 `
w=[0,2,4,inf,inf,inf,inf;  ( U! m7 {8 x% q+ z9 M" q: Y
   2,0,inf,3,3,1,inf;( M2 J  t8 B! g. w
   4,inf,0,2,3,1,inf;                     
% S. e$ `( m1 h' x9 K6 v$ m& F   inf,3,2,0,inf,inf,1;                    
& L/ F* K1 d* ?1 a  s   inf,3,3,inf,0,inf,3;
) Z( @* p2 h5 l6 f9 r+ ^2 Q# L2 q   inf,1,1,inf,inf,0,4;
; }! A$ }# p) k+ `" A   inf,inf,inf,1,3,4,0];
, i6 O2 S' j, {8 s. D2 wn=size(w,1);%记录图中点数2 J1 ~$ F4 ^* g3 |

4 a' b) K1 B/ C) ?3 w3 _0 qfor i=1:n: f9 k3 y9 z+ j1 s4 C
    l(i)=w(1,i); %为l(v)赋初值7 v% Y* M7 p$ k
    z(i)=1;      %为z(v)赋初值1. l7 |+ P+ E$ _+ H/ B
end
# a. t! \3 M9 A+ e4 D0 @$ u5 z' O! n" ]
s=[];            %s集合
: m4 d) H( a* ys(1)=1;          %s集合的第1个元素为起点8 ]% @# b" V- ?' r& |
u=s(1);7 H! o/ Y+ d' N) p3 h
k=1;             %k记录集合s中点的数量
7 L% Y" R. G% P/ F4 U
. g+ ^+ i  s1 Y2 {' uwhile k<n       %当集合s未包含所有元素的时候执行循环+ X. X; G& u: n0 _
    for i=1:n    %更新一遍l(v),z(v)( x7 L6 Z0 A( d3 o
        if l(i)>l(u)+w(u,i)9 ]! a* n* ~. x6 h  J
            l(i)=l(u)+w(u,i);
) a# V: h; j5 Q1 s3 `7 |, v% {4 m            z(i)=u;5 a* x: ?' u  n: }$ l5 d# L7 ^; I
        end
% s" B5 R: ~) E/ O% ]    end' c3 c7 Y7 I9 R  c/ E- F9 d

: q/ d4 ?) F3 D& |    %找l(i)中最小的v加入s集合
8 ^. J% H' @: Z/ L! D, c; W0 E    ll=l;# ~& b3 i; l# \# }* W, P8 C
    for i=1:n
8 e, W0 J; t* ?0 t        for j=1:k
2 s2 r* J/ Y3 I" y, @9 {. x            if i==s(j)5 z) Z& x; s# r
                ll(i)=inf; %去除掉已经在s集合中的点
% c+ C, q$ c6 t1 O5 {  I7 ?            end 3 C9 C+ R8 m$ M9 L3 j3 n" h
        end1 c9 N4 R+ s/ v+ Z/ r7 B
    end0 n' W+ q$ \& W9 T7 t) }( a
    [lv,v]=min(ll); %求最小的l(v)
: S% M. J& K' ]9 Y* K    s(k+1)=v;       %加入集合s: X8 B7 K$ z% |5 |8 Q0 V- v
    u=v;
$ ?: k% ~% O4 [& o    k=k+1;
+ r3 }, W4 g* F+ |& P- G" Uend
0 j* b8 U' b- Y# i  y! z
, ]: `3 \$ y1 i9 C- w2 |  kfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)+ o% B  v7 f6 S" a2 m

0 u3 a  x1 I# K解释:
+ j4 l2 N3 b8 s' b! _3 T( l
  {# u! ?. u' h, S) G" \1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
8 N( f0 g7 m& E" R% j7 }2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
; a! l0 J# e- ^& k+ ]' [3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。& N& U# Q: ?7 M& z
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
3 Y9 X* H& `8 D) e6 R" ~1 \7 }5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。& }3 `$ v% ]& v5 R  k& E, K0 w& x! n4 d

9 @" i2 L5 L1 K: X1 g. i注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
( {  _) e5 j+ K$ j0 Q' d* l# t1 i2 D- f) G* B: U
' h$ F. k7 m7 s; G

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, 2026-6-15 19:10 , Processed in 0.422064 second(s), 55 queries .

回顶部