QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:0 m6 ~% g4 U# n# R( S' ^
clear all  S6 b0 r9 V" K2 q
%图论最短路问题的Dijkstra算法
7 L/ H" E/ G( E" v; z7 ]%邻接矩阵(点与点的关系)
6 k* s+ a; K3 t: m5 a( X6 mw=[0,2,4,inf,inf,inf,inf;  
4 x, e7 X- e/ h4 Y6 |$ y  E   2,0,inf,3,3,1,inf;
1 @, p' ], M" T; f   4,inf,0,2,3,1,inf;                      : }6 @& d7 b7 E. U0 l4 L" T0 G
   inf,3,2,0,inf,inf,1;                    
( P, c0 s, u* s9 R   inf,3,3,inf,0,inf,3;3 \/ l3 p, V, `" R
   inf,1,1,inf,inf,0,4;
4 W4 C! l  g9 h. Q4 S& v8 e& R   inf,inf,inf,1,3,4,0];& R/ n/ X* ~: S
n=size(w,1);%记录图中点数
: m1 P. Y/ k; w. @
( p$ o5 w9 D. _6 N4 `for i=1:n
) x, o3 ?! h, J" ~  Z! K% u    l(i)=w(1,i); %为l(v)赋初值
& o: L+ j2 G+ j# d' V$ ]! n. }( o5 c    z(i)=1;      %为z(v)赋初值1( s- Y- q0 y4 z/ d* n: P2 a
end* R! g4 b9 W6 Q7 I% t
( Z- j4 K$ M5 N
s=[];            %s集合
, {" m1 Q1 D6 [5 Ks(1)=1;          %s集合的第1个元素为起点
) S, V4 T& a% f% Ku=s(1);
3 w  D" b2 @/ Z7 N" kk=1;             %k记录集合s中点的数量
9 f8 E9 s' `- |+ T9 E) @  L3 q) D2 w0 v0 K( w
while k<n       %当集合s未包含所有元素的时候执行循环2 S+ K. _1 z( c7 C$ e" x# l' V
    for i=1:n    %更新一遍l(v),z(v)* p3 x# |4 Q" D0 Z, t
        if l(i)>l(u)+w(u,i)
/ _9 q3 v/ l  }- t4 m. b# [  s! a            l(i)=l(u)+w(u,i);
# x& D. Z! R  P7 `* i) x& ~            z(i)=u;8 m- A/ K$ f) E! V: ~: n( l
        end. {9 M# p9 q( o8 g  f% \
    end
& ~6 n, l6 f9 {: a4 \1 J
/ J) b8 l$ B% F( Y4 ~' L* p    %找l(i)中最小的v加入s集合, S! t8 W( |, {3 x9 M7 f  A& g% F
    ll=l;
) G3 T, }7 M& ~1 b5 ^. t    for i=1:n
4 t' ^# \+ Z+ _* ~# ?        for j=1:k4 T9 N7 n8 x& H$ R* V; H1 {: B: w
            if i==s(j)7 ~8 E7 |" y' o5 w  B3 h
                ll(i)=inf; %去除掉已经在s集合中的点
% I: q! X" V" W/ _. o4 j0 f            end
+ ^1 l. L5 k& A( b        end. v# E5 p, E* g6 O/ ^- v
    end
; G' H' a( o1 n' w7 K    [lv,v]=min(ll); %求最小的l(v). I# W; R* p6 ^; Q# X
    s(k+1)=v;       %加入集合s
' r5 d0 P- q/ W( x* e. ]3 h( X    u=v;; F$ q1 k% {5 k4 t' b4 T
    k=k+1;
0 |: E3 e5 p# W6 u/ tend
5 X. X- Q! d) q! Y' f" w- a9 {: G+ N: [! n  ^0 l& p
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
$ h* D3 X  Q0 [5 ~
  y; M* j9 i# l. r解释:
7 q8 I9 b$ t  z* w" m
' Y5 W. P1 D. a/ l2 Y7 ]8 h1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。9 }% }- T! j& c5 j2 f
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。& r9 Q/ H8 G' b5 {
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。) p2 r% h) S3 q% h$ W8 W
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。0 h2 k' J+ E% q3 |9 {5 s( g
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
- g8 F& G# w; Q) o0 r& l, q( P
注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
4 J3 L% y% q+ h9 G8 m+ i) c) w) w
! L9 P% L7 r& t* l5 @

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 16:49 , Processed in 0.336740 second(s), 55 queries .

回顶部