QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1188

主题

4

听众

2931

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:; r8 X( I  \8 i2 P  k' k. Z% e) ~
clear all
- M8 S% ?! a, {' |/ @0 l- I8 u" t! V%图论最短路问题的Dijkstra算法
  _/ T! b, _' D9 L+ m%邻接矩阵(点与点的关系)0 q9 ?5 E. ?5 i+ S9 h: k
w=[0,2,4,inf,inf,inf,inf;  2 S$ w& e" N& z% w. L
   2,0,inf,3,3,1,inf;
) k$ H9 V  _  ~2 c2 q0 N5 T% g   4,inf,0,2,3,1,inf;                     
! s5 @" P) t9 `" ~5 s   inf,3,2,0,inf,inf,1;                    $ d- H6 U4 d+ z8 ^1 @4 @6 Q* v* e
   inf,3,3,inf,0,inf,3;
, s& {& p# b$ }$ X, G   inf,1,1,inf,inf,0,4;
8 j8 ^/ ^" X" T* m9 F: k7 }, J$ W   inf,inf,inf,1,3,4,0];
; N) R0 o3 Y4 W3 ^# Bn=size(w,1);%记录图中点数0 O) ?7 _% ?( Z  @0 g* a# i  d, ^
, p9 `, }# w! y3 u* R) H
for i=1:n
0 ?, R8 K4 Q" a: {8 M+ j    l(i)=w(1,i); %为l(v)赋初值
9 I  P+ I4 b* I7 |) `& C    z(i)=1;      %为z(v)赋初值1' w- y" M  _% u/ @
end
. Q( ^* {) F9 z' i7 Y* B, J" @; M1 E. W, |' T! E! q  s) |1 l
s=[];            %s集合  ]+ {7 Z" U& {3 `- u0 {
s(1)=1;          %s集合的第1个元素为起点
. s6 b9 l! J3 \0 M/ e4 Vu=s(1);
$ o- o& F7 |6 V$ x) N0 V' F) p" Ak=1;             %k记录集合s中点的数量9 F& U+ ^( T8 t# @, o, I

* o7 p& m0 O/ ^% S+ O' Wwhile k<n       %当集合s未包含所有元素的时候执行循环) d) b0 T2 n& O* `7 ?* H, i
    for i=1:n    %更新一遍l(v),z(v)& d$ I# }! A% b$ r
        if l(i)>l(u)+w(u,i)7 j; {) M4 s  @4 ?6 Z. t
            l(i)=l(u)+w(u,i);( S) V$ M; a; B" T2 U7 z7 k" j  }
            z(i)=u;7 G" c" J1 \9 z. \1 H- H
        end( C/ A  f8 x7 j3 O9 z5 L
    end
1 i$ c. X& n0 N' R7 k, p+ J% O7 U
) L. M* w# U' M  C: b( d  t7 _    %找l(i)中最小的v加入s集合  L- x1 \" ^1 _: I6 e0 l% w4 ~
    ll=l;5 M+ R# u$ W+ m. C
    for i=1:n6 F8 f1 b% ^! l! E
        for j=1:k
& j  i! H! H5 W9 @1 X+ D            if i==s(j)
( _% X& l9 `; G+ K/ l, e                ll(i)=inf; %去除掉已经在s集合中的点
( v5 U7 o& H- m. P6 x) w            end
, N' @2 G  C! g5 f) y9 I        end
& G$ |2 U* i3 c" [    end
' q, P8 e' S: {& j: Y    [lv,v]=min(ll); %求最小的l(v)1 n3 L0 e  n( g1 `0 g/ r! V, J
    s(k+1)=v;       %加入集合s8 u9 n( l% N( M; Q
    u=v;
. S4 }4 K1 W/ b3 o' n( v* D    k=k+1;/ F2 @1 ?& K1 y  `
end
" r' W! o+ p3 [  J6 L: b2 Q% X! o
6 E; ?7 f1 r! Qfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)9 Q1 ~9 d* Q0 |( x( \. `- e

* T7 Q! m+ W9 z; |' G解释:
2 |; B/ ?  c: N( o3 D* j
3 j! |; q( @" t1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
, g+ k8 o$ F4 v7 A2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
, S% w% g: `- o; D3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
4 \3 f' Z# v; b9 i! q& T/ N4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
3 ^  C1 u4 y8 m3 k" h5 J- |5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
! Q% y5 Z3 A( i7 F: `3 t  j/ t
& A$ _& L7 i5 t注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
3 n! w1 `. t  P$ R# v9 ^; a1 v, Q9 h9 N  j* k  y0 U1 s
# N8 H5 X& d( e1 b7 a- a# u

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-5-26 05:16 , Processed in 0.364897 second(s), 55 queries .

回顶部