QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1176

主题

4

听众

2887

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:) R' ?* O9 y* u9 H6 Z+ R
clear all' K- k( s! v5 y# S
%图论最短路问题的Dijkstra算法' `; m4 ^) f3 b  i- y* z
%邻接矩阵(点与点的关系): n5 r7 g. V; a6 C* V# T
w=[0,2,4,inf,inf,inf,inf;  
) k  a1 j+ _) p3 d" E! v+ ?7 o   2,0,inf,3,3,1,inf;
2 R4 d' W) @' C  e   4,inf,0,2,3,1,inf;                     
" g, E; r& f! ]" Y' P: I   inf,3,2,0,inf,inf,1;                    ; |, V( ?; P3 Z/ @5 j# E
   inf,3,3,inf,0,inf,3;. A3 X, ?# R8 q" ?
   inf,1,1,inf,inf,0,4;
) L  s" ^* v& a" m   inf,inf,inf,1,3,4,0];- q) y5 T7 f0 J) n9 Z  q
n=size(w,1);%记录图中点数+ }  T, B8 l( ]  F5 E
6 o" ?9 m/ o2 M* H$ N, i! x9 s
for i=1:n
' U8 w/ B- |! a8 o/ `- Z' I    l(i)=w(1,i); %为l(v)赋初值
4 R/ [% C# k4 |+ i. f0 \    z(i)=1;      %为z(v)赋初值1
/ _' O: p5 ], ]2 y/ J* Send
3 j! N0 D/ Q0 N* ^& f: o" x; X' O) F3 r7 y( N* d' g9 I1 e
s=[];            %s集合- x: B0 q- e5 U; G
s(1)=1;          %s集合的第1个元素为起点
: K# G( W- Y+ N+ i. j9 Su=s(1);" P5 e" I- X# ~- H0 K1 Q( i
k=1;             %k记录集合s中点的数量  K4 `# z1 I" M
+ t& E" H7 d( `; G5 j$ Z0 Z
while k<n       %当集合s未包含所有元素的时候执行循环' k7 e/ `) }  y* f& ~
    for i=1:n    %更新一遍l(v),z(v)8 @! a6 I: U/ Q; C) k3 y) J" X& p
        if l(i)>l(u)+w(u,i)# K4 s6 d/ ]" }* p$ i3 F0 @& i& i2 ?
            l(i)=l(u)+w(u,i);0 b$ d* v- I7 Q; h0 X8 {" I+ {- v
            z(i)=u;8 s+ y  C+ g" h
        end
4 A3 C# J* L- y$ K    end3 M0 P5 D; B" Z( A

9 v2 J. K$ v8 [9 H, h3 H/ ~    %找l(i)中最小的v加入s集合$ D0 d, T8 S& T, c
    ll=l;* E( h; R( R7 y* q5 u1 U: ^; ^
    for i=1:n; W, y$ A+ U) J4 K& M) ^
        for j=1:k) j- S/ u6 o- m9 b  P$ ], O
            if i==s(j)# z) Y, G3 G! h6 z5 ?- x  X. F
                ll(i)=inf; %去除掉已经在s集合中的点
- ?& f0 V  U' ~9 ]# e            end
. x: J! ]% Y8 h% ^* H7 I        end
: l5 p5 D9 ]9 G% ^    end4 `7 i4 G9 y1 C, M4 N4 J# x* K! i
    [lv,v]=min(ll); %求最小的l(v)1 s9 u1 r* L/ {" e/ [! y
    s(k+1)=v;       %加入集合s: d/ N7 G9 t, d6 H) o
    u=v;
0 ]& x( ^9 V( I" {" ~    k=k+1;
7 E1 ~$ E; p! F3 r+ Q, V  fend
0 a' r) H" D9 ?7 q+ [# _# }) P  ^1 M* J
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)% K, D. b* J. L  a0 o" M
6 \: C" L& [0 _/ F; _1 \$ a
解释:
3 [- b! [" B! B( V- h
$ L( N& g! t/ ]; H1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
3 S, S. O1 D( v3 X2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。( e! ~. h. i+ L  d
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。6 H9 @; z: Z9 [/ ]
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
0 [# ?7 S! e. F/ Y1 U5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
- p! |3 e, I# o+ {
$ P, l& q- t" j* e6 ]+ q. r5 L$ @注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
6 G9 a+ y" G5 p0 }8 j! Z) m% o
+ {- K& S, Z/ j6 l% q# z3 P3 `; P

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-11-3 11:59 , Processed in 0.414283 second(s), 54 queries .

回顶部