QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1175

主题

4

听众

2804

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
5 l- B' n! R2 h/ i1 ]clear all
. u* t) S/ _  _  d, w; ]%图论最短路问题的Dijkstra算法- ^6 k; f1 z: k' n
%邻接矩阵(点与点的关系)4 R7 ?9 N: W. J6 u0 x5 |$ z4 X
w=[0,2,4,inf,inf,inf,inf;  
/ K- o- z( T& j  K6 J9 t* o   2,0,inf,3,3,1,inf;
6 c, e- J" U2 Z8 P5 x- S   4,inf,0,2,3,1,inf;                     
8 D' M; x5 f9 m0 B/ i6 {   inf,3,2,0,inf,inf,1;                    / o6 `3 f3 q! D1 B. w* E  A
   inf,3,3,inf,0,inf,3;
& Z8 }2 g. `8 k% L# V+ w# [! b   inf,1,1,inf,inf,0,4;
+ o( f# ~+ g+ c   inf,inf,inf,1,3,4,0];7 o- x( P/ g' L/ F+ f7 ?
n=size(w,1);%记录图中点数
) [- n1 }8 c+ j2 @; ~6 {( B- m7 J& ]; G  J+ M5 A$ R- T5 l' H
for i=1:n3 l) v& k/ Q3 Z  u" o8 w
    l(i)=w(1,i); %为l(v)赋初值! w$ U" O: b0 x' r& V
    z(i)=1;      %为z(v)赋初值1
0 A! ^8 ?6 s& v9 x" u4 U3 aend3 k0 j4 Z% P; E
0 P  `" \8 D& i* V6 t! \
s=[];            %s集合
7 a" z1 i0 z: m7 ss(1)=1;          %s集合的第1个元素为起点/ E. g* b1 w7 g- U
u=s(1);3 u' d4 T5 v, O! G: [7 W
k=1;             %k记录集合s中点的数量, {! V2 v0 r5 ]9 v3 o4 s

1 _2 d0 F. K- s( `- Dwhile k<n       %当集合s未包含所有元素的时候执行循环9 c5 w$ L8 k6 |) m+ K7 f% @! R' g
    for i=1:n    %更新一遍l(v),z(v)6 A% T; Q* b1 r. F; T+ N3 U
        if l(i)>l(u)+w(u,i)
( X7 h0 q2 G' j4 R* p            l(i)=l(u)+w(u,i);7 ?  h" i- X& k# i; |
            z(i)=u;
  u5 Y* j+ V) S; E9 |: V& c        end
0 U! @8 H6 |% ^    end
5 I- f$ T- h1 i* C4 [6 g; O) W+ G6 R0 `5 A# r8 ~. y
    %找l(i)中最小的v加入s集合- H: \2 c$ S. y, g- F5 {5 N( J
    ll=l;) `  |8 X- R0 K7 t
    for i=1:n
$ Y5 S0 D5 V( n5 |        for j=1:k- Q7 W: f$ L, a1 A
            if i==s(j)- S8 ]  z& |; I
                ll(i)=inf; %去除掉已经在s集合中的点* S. W7 H* Q" _& s
            end
' H5 {0 E, ]# z" g& H/ E        end+ A, h% K% t* {: G" ?8 [) w$ x& ?& u0 X
    end9 @' B! J9 q. f5 j
    [lv,v]=min(ll); %求最小的l(v)
# K* u- ^+ Y9 A; @  ?) |3 Q    s(k+1)=v;       %加入集合s2 C. _: d& {5 d( u
    u=v;7 }9 B! I1 M1 ~3 [8 S& N  h
    k=k+1;
& P0 Y1 V6 J" H: y) lend
/ U: T, `  Y) B# o8 A0 U
$ }8 ^. |$ _8 s7 {) g! X7 N' `. Mfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)( G- B1 D* Q# S) V# |& y; q' d
6 L% d6 g( ~/ N; @  ]1 `9 |
解释:
7 @  h" P( a1 T4 b# W
+ j/ B% A' _" Y* g1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。$ R( ^1 R0 x/ f3 p4 [' I+ o
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。1 w: N  ?. a& U% v. H; r# g3 Z
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
0 L7 m7 [5 g! g  ^" t4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。+ \1 W4 G3 I4 Q5 U* l& |
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。! r1 V: s5 Z( r. S" J- C# [

3 q; n% @7 k) i/ a- x注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。( P: j! a& [; U

3 h" g; K- t" T6 f$ g3 N* K- |, p% n9 D

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-8 18:42 , Processed in 0.480037 second(s), 56 queries .

回顶部