QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1175

主题

4

听众

2809

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |显示全部楼层 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
( `" L' f" ?) O  Qclear all1 ?) P* f& z! f
%图论最短路问题的Dijkstra算法
1 C$ F/ _+ s4 k* D+ X6 I%邻接矩阵(点与点的关系)$ w! ^" {; c5 K* J8 m1 B9 Z: v
w=[0,2,4,inf,inf,inf,inf;  
) R1 f: s3 J2 L+ c# W/ y   2,0,inf,3,3,1,inf;0 Z& O1 P# E& u  W2 c2 f" z
   4,inf,0,2,3,1,inf;                     
  w+ T) n2 d3 S" N; S" x3 ^   inf,3,2,0,inf,inf,1;                    ) W! U3 G7 z, _2 ?6 V# u+ `
   inf,3,3,inf,0,inf,3;
7 C) C; a. e/ x7 V1 k" X   inf,1,1,inf,inf,0,4;) H) I6 w3 e5 u; L9 D
   inf,inf,inf,1,3,4,0];& R, l3 @$ _; C5 m# a
n=size(w,1);%记录图中点数6 T3 [8 P9 q! q! @. j2 `
/ r8 u( h7 m+ A% z4 r$ V+ E
for i=1:n
1 g8 r4 r- w' m' T- ~; o# {    l(i)=w(1,i); %为l(v)赋初值) n7 f: a/ \4 E  U; f( V. m' V( f
    z(i)=1;      %为z(v)赋初值1
* X* K" G: M2 [; T0 N+ Z1 }& Rend% ]8 C6 k- o5 a3 z; _, g
5 x% H6 }! F5 v. g. H2 |; e* k) A
s=[];            %s集合* D4 e6 Q' t2 K/ g# y
s(1)=1;          %s集合的第1个元素为起点
9 x- z: N  [1 Z* j$ s1 W  pu=s(1);
* [: \$ A) w- \' R# v1 O5 g  qk=1;             %k记录集合s中点的数量
* k/ c# n7 T- }# |4 L1 D# ?3 ^- E/ ?9 a! @3 l9 G& p5 W/ a; U
while k<n       %当集合s未包含所有元素的时候执行循环* [. M7 o+ q  k) Z/ x
    for i=1:n    %更新一遍l(v),z(v)
2 [9 g& T- F2 f% ^" i9 ]        if l(i)>l(u)+w(u,i)2 l7 {5 K' |* N& c0 w
            l(i)=l(u)+w(u,i);
& M2 q7 l& V; d) q' O$ V            z(i)=u;
# Y$ K0 N6 o) t9 J/ d8 b        end
5 r! a( q; }) O3 b    end+ M3 U( _7 X/ z- u- Z* U3 X/ J2 o$ j
9 u8 B& J* _" Y7 }8 `; f+ k. b& Q
    %找l(i)中最小的v加入s集合
$ P" p" m; t  k5 X; B& h! e% F    ll=l;
0 R/ R2 H" C8 {7 c    for i=1:n" p, p+ k4 N6 ~# R4 E
        for j=1:k
. g% A2 z4 F+ }            if i==s(j)6 u" n7 M% z  G. A+ L: k
                ll(i)=inf; %去除掉已经在s集合中的点2 l* f! p2 N: X. X1 {3 t. ~0 n
            end
1 y6 B! m% c" e) c& O        end
, `2 [& y# e+ v    end
! Q- |9 N  h; I2 I; F    [lv,v]=min(ll); %求最小的l(v)
# _3 U/ U4 `8 W, n    s(k+1)=v;       %加入集合s
; J6 p  S( d9 h$ m    u=v;
* E& h5 w' d, O    k=k+1;
1 e4 |& _* N  z1 [* Uend9 \1 z4 P5 ^' C
; E( ~' M) a4 o0 J2 ~) U7 d0 D
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)5 N0 T1 @1 N' |
" J7 Y, C- ^8 x0 M- T
解释:& K: L! j  \6 L" n) I

% Q; v  C2 w2 q. z  r; T1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
/ R1 t3 z8 ?$ A7 d  a  W0 G2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
$ n" M& [* h2 u3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
8 P8 G/ B# |+ t4 z4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。& l* \0 D6 V: W9 |+ g
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
1 s. B7 l( w& s1 l$ v8 `
$ w0 {3 K. m0 z5 p. @注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。0 u* O/ h; i2 F* ^! Z2 H9 g  s, o  C

7 R$ D& N/ W+ c6 Y( ?3 b1 }# `. q/ M$ H' Y' 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-7-9 02:19 , Processed in 0.540422 second(s), 55 queries .

回顶部