QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:# _0 k: m  k4 G3 B7 ]
clear all
& C  x, c3 D3 n% f%图论最短路问题的Dijkstra算法
9 {% r  u0 x1 e) W. q1 L* \%邻接矩阵(点与点的关系)
+ P. G! T! G1 @# Y4 }6 {# o) yw=[0,2,4,inf,inf,inf,inf;  : f. X* m( V% L, O1 l
   2,0,inf,3,3,1,inf;
; X- M1 p3 H" \   4,inf,0,2,3,1,inf;                      4 l. ]6 |* ?$ E7 W
   inf,3,2,0,inf,inf,1;                    
7 T- B$ m5 {4 t, F: G) H   inf,3,3,inf,0,inf,3;
$ H! e1 H" s! u! F  i   inf,1,1,inf,inf,0,4;
4 t3 |* f: I" `  @% i3 G  d   inf,inf,inf,1,3,4,0];' P, G: O/ g. s- b+ ^# R
n=size(w,1);%记录图中点数& H2 L/ A" c% E. ?
( D  V# H2 D2 L; X
for i=1:n$ T8 ^* |8 s" y5 s' ?
    l(i)=w(1,i); %为l(v)赋初值
/ q' O1 }1 b/ x. [% o    z(i)=1;      %为z(v)赋初值1* {3 g) J. W4 o2 [3 r
end
  f: A; {# P  G1 e0 i5 w4 F: q, C; b# R7 u9 U
s=[];            %s集合  e& p) K0 U1 O7 j2 Q* m! ~
s(1)=1;          %s集合的第1个元素为起点
; o  l* |2 T3 J* [" i  c! x, r- Iu=s(1);. u; X6 S) V) u& W! G. C
k=1;             %k记录集合s中点的数量3 a0 L2 E9 g, R  c/ |" m% M/ h
, ^. G" P0 O& o7 F0 l
while k<n       %当集合s未包含所有元素的时候执行循环$ W- J2 V2 U  t( \
    for i=1:n    %更新一遍l(v),z(v)
1 E; K8 A8 q& x0 ~  E. j5 r        if l(i)>l(u)+w(u,i)% @, l7 R% x  t2 k
            l(i)=l(u)+w(u,i);
6 b" p' X7 t. y! ?, U6 N/ n" Y            z(i)=u;2 M! m% e  t/ T$ b
        end! L; t2 }) v1 l! S! P
    end' l3 v  ?, E& j" x% y+ Q  S: f/ s
5 R, v9 z8 e! D* q6 s' e
    %找l(i)中最小的v加入s集合6 l% V# F0 X3 P4 g& v
    ll=l;
* h7 v: c+ c9 J! v. u1 l' l    for i=1:n# t& ^& m1 o, }1 ~( s: G9 {
        for j=1:k
, e7 ^) l- r: {( G, q4 f            if i==s(j)5 q9 }' U% j& e! m. p9 u) Y) T+ f
                ll(i)=inf; %去除掉已经在s集合中的点
6 E! |+ V. G( @+ I, t( I9 q            end . r! I& x: H0 I/ b% u- W
        end+ G: z$ C" C% V% R% \4 `
    end
" i2 `7 E! q" w4 P    [lv,v]=min(ll); %求最小的l(v)/ |$ c1 a9 R3 ]% Z' q% ~6 M! Z0 L9 F
    s(k+1)=v;       %加入集合s- }4 t& L& C1 a. w! X
    u=v;/ x; ~+ ]/ Z# d
    k=k+1;
* W9 i7 j; k$ h2 _' E$ F$ z  Qend* T' b" G" L' W1 C

7 O4 ]0 g7 V& gfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7), q9 j5 B+ s! Y  H9 I0 R' v
% E1 T6 q& l( g! X) v  b
解释:7 ^2 k: i* }$ J/ q
! p  M) p5 @3 ?3 i
1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
0 M  O* {' L; D! G2 i2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
3 X$ p, i; f& u  D: z0 [# y3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。  S: h! a& i  h7 ^+ [
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
2 r0 W$ Z+ p5 T7 \6 s5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。8 l1 L" e( c' x7 M- T' u& D

+ G  P& i( @+ m注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。! I. Q8 H1 D) M( M4 `
6 X7 U' D& \& W! k( ~1 e! r9 h' b
* V- M6 E1 {- H% H; @# A# b

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-16 05:13 , Processed in 3.785791 second(s), 55 queries .

回顶部