QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
% G1 B, n; f; j# K0 l% bclear all
1 \  F/ u- _, S%图论最短路问题的Dijkstra算法+ O, o! |  }. ]8 Q, S$ K
%邻接矩阵(点与点的关系)
+ Y2 I" K2 H" a5 ]* \: k( c7 Aw=[0,2,4,inf,inf,inf,inf;  
0 b5 g9 d% F& z5 _9 M. B   2,0,inf,3,3,1,inf;5 q! {9 A: I  V0 z- L% C
   4,inf,0,2,3,1,inf;                     
" @5 A% f4 V; Q* |% a! ]   inf,3,2,0,inf,inf,1;                    : j8 I( H$ ?: ^2 Q. e- K/ D
   inf,3,3,inf,0,inf,3;
1 Y+ N4 k6 n) e/ b' i' e. L" E   inf,1,1,inf,inf,0,4;
* f' @' H: Q& L  `$ ?1 m7 S3 ~   inf,inf,inf,1,3,4,0];! Q& @- _, L! e$ c( H7 p5 H: U
n=size(w,1);%记录图中点数
6 p" G7 ^0 O7 |- g! _: x* b$ `" s; z2 N1 f2 ], s
for i=1:n
6 u9 m; N2 u$ k* }- d    l(i)=w(1,i); %为l(v)赋初值
3 m# S% k3 \) v. K! W    z(i)=1;      %为z(v)赋初值1
- Y( i& m" ^. p# Zend0 ?+ G+ |4 r+ t! @9 X+ A: c
" J6 c- P  m  i( \9 J
s=[];            %s集合2 X( X9 \* M- f+ b
s(1)=1;          %s集合的第1个元素为起点
/ K( z" m, W, y$ c9 pu=s(1);5 [0 O, a1 P, v$ R) P, O( H+ C
k=1;             %k记录集合s中点的数量
6 f! S1 s# u+ V. j! A4 h- I7 J
8 y3 p* J  Y1 T5 qwhile k<n       %当集合s未包含所有元素的时候执行循环
& \  X2 }  ^0 ~    for i=1:n    %更新一遍l(v),z(v): A# Q) V; |4 C) g
        if l(i)>l(u)+w(u,i)  ]5 M" O3 d2 e$ v0 R- t3 P2 [& a+ p; J
            l(i)=l(u)+w(u,i);
, v( P5 {- c' s* h+ e0 {1 [            z(i)=u;+ Y- n& v% c% E, a5 c3 c, B8 @- s
        end
0 i  u  v  H. b" E# g    end) m; q; g- A5 a

4 d0 d, k$ C! i1 r% V    %找l(i)中最小的v加入s集合
; [7 }% P; Y9 u, y    ll=l;8 H2 l7 h. T9 R: _' P# r
    for i=1:n# X! h5 S' E' C9 X; }* C
        for j=1:k) Z$ J; O* ]8 Z
            if i==s(j)
& G% `9 I) k9 [: O                ll(i)=inf; %去除掉已经在s集合中的点% B& c6 P, d' V8 E
            end ) l$ _" u, u' L
        end
* |4 \* L7 X& s) p    end9 A2 F3 o7 I: ^/ l# D& e  ~( c
    [lv,v]=min(ll); %求最小的l(v)! g7 V5 O( S- y+ X
    s(k+1)=v;       %加入集合s
) r( V: H4 G5 w: E) Q) _0 T8 [$ h    u=v;
- [$ ]8 }. l% L1 E( U5 v' r    k=k+1;
6 U; c- w) M7 N: @end7 |7 V1 O; T; r  o7 m

3 f0 e9 y5 G8 l- j: k0 Bfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
* H5 P2 a/ h; r1 v4 X3 G% M
* r4 @9 X: f1 i( S( J( `解释:
4 X: l0 ?" |: W8 A
  G# \1 C7 Q7 V+ V9 [9 a1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
' F* @) t( H7 R" _2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
9 |& Q3 A* j, I6 \3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
. x  Q6 m( }2 T% c- n' |4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
% w& d) Z: l& @6 a4 a' _" q2 s8 _5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。8 e$ U! O4 C4 ?0 X

5 E; w- v3 b7 S注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
( X( }2 G- x# T8 [# Q3 H. w/ s8 y* k) c, h2 O- U1 ]/ Z: p
) p4 P: F! k% H/ B" M

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-4-10 15:08 , Processed in 1.522916 second(s), 55 queries .

回顶部