QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1185

主题

4

听众

2919

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:( F1 ^' E* O( d8 m7 F
clear all
/ s- I, x- {6 [+ o%图论最短路问题的Dijkstra算法
2 w+ @, k) ~* M/ Z# U! y2 o$ _# Y%邻接矩阵(点与点的关系)
1 ^4 q, h0 Z6 j( E: Yw=[0,2,4,inf,inf,inf,inf;  2 _2 X2 Y# C4 M" a) t
   2,0,inf,3,3,1,inf;! l' K( X5 z$ [! N9 K
   4,inf,0,2,3,1,inf;                      0 B5 H+ O  h" @7 [$ ]
   inf,3,2,0,inf,inf,1;                    7 [! c' ^" |) S/ C
   inf,3,3,inf,0,inf,3;
, l3 _. v; g) g3 o6 @/ `   inf,1,1,inf,inf,0,4;
- N% T8 r6 R7 b7 ^0 c: t/ ]) V( x   inf,inf,inf,1,3,4,0];
0 ~. {$ M" F- E- ^n=size(w,1);%记录图中点数
& T* p3 o5 j3 _; h" D% M5 K- {
) W3 ?, G2 a2 B, @, Sfor i=1:n
# n; L! I7 H  B9 t  g" i    l(i)=w(1,i); %为l(v)赋初值
6 X% Q! N+ S, C& _6 Y    z(i)=1;      %为z(v)赋初值1
8 u. W1 r& q% S2 v6 c* X" Lend
1 r$ A, @( K  W7 l: H& Z
% i* F5 n7 V: Ks=[];            %s集合
3 |  B+ C& q2 |2 A0 Vs(1)=1;          %s集合的第1个元素为起点7 Y% k" D. g; C
u=s(1);) @# c# J/ C, X' R
k=1;             %k记录集合s中点的数量
( q/ K, Z; R  I6 x$ |) T+ @3 _8 J) q, k+ F9 n4 I1 d) {
while k<n       %当集合s未包含所有元素的时候执行循环6 \, c' P) @% D2 L  U+ K) S
    for i=1:n    %更新一遍l(v),z(v)
4 A) _0 x$ z. v) c        if l(i)>l(u)+w(u,i)5 z$ u2 F' T/ H" [9 k
            l(i)=l(u)+w(u,i);# B$ D) J1 D8 g' W/ a
            z(i)=u;
, {% A1 d( d! T+ U/ R: L" ?( U! i        end
. `9 a9 p; @1 i  [2 c. X7 i, w    end
8 J2 o' @& t) q0 W9 h0 o7 G3 |
3 b0 C& i: G& @2 z1 g    %找l(i)中最小的v加入s集合1 j1 z# x( w) r9 K) i# {( n
    ll=l;
7 X" H* ?! E  y3 ^; r    for i=1:n
: s3 X6 ^4 B1 J$ K/ t        for j=1:k
) [7 z: F0 r7 F8 u( r( Y! m- O            if i==s(j)
0 `0 D) Y. R7 U& u& f                ll(i)=inf; %去除掉已经在s集合中的点
4 j- O0 J& @5 H: a( n8 z4 V            end & A0 c9 ?+ \/ h3 J4 y
        end
: {7 a7 l# S7 w    end( V7 K0 }6 c( G, |9 v7 u; T
    [lv,v]=min(ll); %求最小的l(v)
1 }; ]8 P4 V' f/ d% y  T& c    s(k+1)=v;       %加入集合s& i1 v6 \9 n1 z" E( A
    u=v;) P2 ?. o3 ^6 N6 q& D6 _0 m, P, i
    k=k+1;9 r3 C5 {  X0 ?
end; P, R; r% k5 |+ C( S0 j
5 ~/ ^0 O# t: I' o& Z
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
8 h- k7 T& ~& ?/ D8 o* m9 V* P
- J, t- F: x% @  J7 F6 s解释:3 _. n4 l( G, l4 d

! T  \- I3 Y; M$ \8 H) ^1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。4 Y; t, L$ K+ z+ I; D$ _( w1 O
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。8 X' d; b( R! Z& h
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。6 G! c0 Y( b4 _, p
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
2 G$ b$ ^& K! k& ^' X  I+ w5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。+ ?* k+ V) ^" R! l- y# L, n
) ~$ i- `  P$ h+ |9 ]. m
注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
- r+ _* I! P! v- R# p1 u- _: i0 T8 |  S3 F0 V- f
$ o1 Y. i' |* k4 U1 _6 I+ i

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-1-3 12:45 , Processed in 2.011002 second(s), 54 queries .

回顶部