QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:% c4 J1 I4 l2 [" _% k
clear all# m' C) }& Z8 A: u2 q" @
%图论最短路问题的Dijkstra算法6 i* h* W- Y7 t- e
%邻接矩阵(点与点的关系), w& L3 u% a1 s2 `
w=[0,2,4,inf,inf,inf,inf;  
$ U9 N! d1 \; ]   2,0,inf,3,3,1,inf;
) z5 m3 I# F, Y: s   4,inf,0,2,3,1,inf;                     
' i" [; d. b6 @; ]( h   inf,3,2,0,inf,inf,1;                    
  T3 S# i, H& p) s  E   inf,3,3,inf,0,inf,3;% x/ N  X8 F' b; e
   inf,1,1,inf,inf,0,4;3 J) J/ F6 ^5 m/ d7 r, h8 b! m  V
   inf,inf,inf,1,3,4,0];
# p. r9 u! m! }4 c+ Jn=size(w,1);%记录图中点数- W& [* A6 @5 ?( e: H
: K/ `0 V' q8 f, f) K/ h
for i=1:n1 d2 B% o( b( `* q1 I
    l(i)=w(1,i); %为l(v)赋初值
" M4 f6 a9 Y# v. u4 A    z(i)=1;      %为z(v)赋初值1
7 r; G4 w  h- @- gend
, I$ h9 Q& p+ k% V9 ]! {' E; O+ \- I
s=[];            %s集合: c- `3 G4 W. w# r: r
s(1)=1;          %s集合的第1个元素为起点
% }# t8 Y. c6 bu=s(1);' U1 S8 ^2 {2 _0 B& w  j3 [' a
k=1;             %k记录集合s中点的数量
8 w0 C( F; q9 A6 c9 s" U* S$ c, u9 s' d+ A) l3 ^1 {
while k<n       %当集合s未包含所有元素的时候执行循环
& E( \  d- `6 H4 e    for i=1:n    %更新一遍l(v),z(v)1 [  h" v6 p/ o+ O3 ~, _2 }1 @
        if l(i)>l(u)+w(u,i)
$ H9 T# S  i" I8 v            l(i)=l(u)+w(u,i);
0 V6 g: h1 l# I3 n            z(i)=u;
- l% m& N& j, C# d8 ^0 q        end$ q! B, d! L' d) ^* k5 K
    end
7 X' p" d8 p" u/ o. N" t& B3 e  L! ~7 O& p2 \' p
    %找l(i)中最小的v加入s集合
0 B( s& ~3 P+ e9 N    ll=l;( e1 N+ L- f: F% A: z
    for i=1:n
& ^8 c. ^1 v6 a9 z4 m9 a        for j=1:k8 H7 B8 ~1 n) ?" I
            if i==s(j)* B( R. b' L# D9 E9 u; y. c) n2 ]
                ll(i)=inf; %去除掉已经在s集合中的点2 d* u$ Q- f) Q4 u( X+ f+ I
            end
& r9 L7 S  t  }! ^6 h- o        end! p+ x9 S1 C+ f+ Z
    end
5 ?& v9 [! R: g( |4 U7 Z( O) g" O    [lv,v]=min(ll); %求最小的l(v)5 b. H' b" c  J; E' I) X) M. U
    s(k+1)=v;       %加入集合s1 f( D9 @6 m; k: k
    u=v;" I1 W# u. Z. B" c  v, \
    k=k+1;
. p: J& Z% [( q7 r$ d/ t# `. E; l% {end& @* c& J8 T4 A- l1 Z2 c7 U
2 |" Y5 [# i/ d3 A# b
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
% ~% d6 i+ {% ?* U' L& T+ o& W' v
4 \( ^6 f& Z* k7 m) i解释:( Q) h$ }% r5 j+ t

0 R: s6 s! J+ ]' B1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。/ k) _+ V) G5 S# o0 e
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。. G0 [) \7 C3 d! Z7 z
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
: o( M( Z4 z' b! ^* Q4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。) ^- }* }0 J9 i3 W
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。) p1 _5 ?7 ?& J+ I6 I

( i) h1 K2 v7 Q. r. S; B7 ]注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
8 q& c7 l. \; ~$ i/ n* o+ K( M% Z
$ q8 Q5 c$ M7 k: _5 q4 G% T
3 A6 O" y( T9 A7 O, B( i* r+ [- j) U& K

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-12 14:26 , Processed in 0.434440 second(s), 54 queries .

回顶部