QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1176

主题

4

听众

2887

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |正序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
6 o6 B; @# x$ |clear all, f1 A" o, |$ @$ y: [+ V; ]
%图论最短路问题的Dijkstra算法
" Z$ D6 ]' r9 T3 a: q%邻接矩阵(点与点的关系)
; o5 d' |5 I* R9 Rw=[0,2,4,inf,inf,inf,inf;  ( R& `6 u, ^5 Q- p! v  D- N
   2,0,inf,3,3,1,inf;
* {. J$ G1 b9 N/ e9 t. r- q   4,inf,0,2,3,1,inf;                     
( `; p) C4 d- J; N( m0 Q3 r0 n1 J   inf,3,2,0,inf,inf,1;                    3 C9 S, p$ c6 }1 t
   inf,3,3,inf,0,inf,3;8 N/ h4 T5 t1 I
   inf,1,1,inf,inf,0,4;
) `' j: _  ~+ Z4 [   inf,inf,inf,1,3,4,0];
# P) s* a: b. F8 N: Qn=size(w,1);%记录图中点数
; `2 {! h* _) C  Z+ o# ?; Z
, u) Y7 u/ f/ @! E# C% Ifor i=1:n
7 d3 e5 s! v" C0 i    l(i)=w(1,i); %为l(v)赋初值$ T* S1 J/ D! Z2 h- q# P; a
    z(i)=1;      %为z(v)赋初值1
. r( |2 s9 D5 m7 a$ Z  Hend
2 Y- w1 u1 ?$ K1 a  o: A
9 Z7 T8 Z2 Q5 H, M2 vs=[];            %s集合* |! v9 I5 f. k: }0 w2 O4 l
s(1)=1;          %s集合的第1个元素为起点7 |: M% Y8 ]6 ]4 h3 R* b' k
u=s(1);5 s; E! {8 t0 P! D& r$ [) j0 R" p
k=1;             %k记录集合s中点的数量
& E$ c# U, D1 U: O0 w& R/ F6 G4 u; b3 P5 U1 u) U$ h* {
while k<n       %当集合s未包含所有元素的时候执行循环# p% F  k( O6 }1 p, C
    for i=1:n    %更新一遍l(v),z(v)
& @; t$ B. J7 S        if l(i)>l(u)+w(u,i). h8 Q: n6 F4 R- j" p
            l(i)=l(u)+w(u,i);
% ?1 S8 z0 x* x+ h            z(i)=u;
9 {9 C4 i0 T- U+ f        end
3 o0 `* R; F6 B+ |& D: S" e    end" l5 H0 W) C2 g- R

. l. t9 q; I9 H5 X7 t6 c    %找l(i)中最小的v加入s集合
' Z$ e/ |0 {5 c# [2 _3 b* f2 s* n    ll=l;. _/ h6 ?! o* h% Q2 i7 g
    for i=1:n
% U% q: N6 |' D" e* Z* X& [+ i, W        for j=1:k2 b+ a: V/ h' l; i* S. V& U
            if i==s(j)
7 Z* \1 g) F  H, m& r  K% f, Y/ g                ll(i)=inf; %去除掉已经在s集合中的点7 G9 z# G1 K+ n$ O% o0 Z" h5 E
            end 4 {& ]; M' Y+ v" i1 d% K
        end
. y7 o: A' Y# v( a+ H  P    end, g' p+ m& I9 W4 E% @$ e
    [lv,v]=min(ll); %求最小的l(v)
$ [. P/ p5 E, I2 R    s(k+1)=v;       %加入集合s
8 }( x0 I5 n' m+ u# ~    u=v;  ?4 o. F/ K- m  j
    k=k+1;6 d3 \0 v7 R) e& a/ Q/ B+ y# F
end1 d5 B, C; H# \! s( r2 m* G
! r5 I9 I! W/ C4 b7 d) M+ g
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7); T5 k2 ~4 i) k/ V9 Q/ \

) Z' X( I- G+ C! h- C. V* f解释:2 A* c5 w) r, _6 d

0 d. ^# `+ }. B, m7 X- t6 c6 @1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
# g! G: ~0 y6 R) C6 I" Q2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。8 O  ]( |2 W( I3 W3 }1 j
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。7 V6 }, Z4 y5 M( y0 Z' t
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。2 B/ x# i- I) I* S* w1 ~
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
$ Q! T% D# ]/ l& f* e0 b9 u; b0 b
! a  V/ @* k" [6 W" V6 n注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。1 e; J& k; }/ S1 u6 r

" U6 R& c6 `- s4 K% b' l" Q9 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, 2025-11-2 03:13 , Processed in 0.698796 second(s), 55 queries .

回顶部