QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1171

主题

4

听众

2780

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
1 \1 L9 ^+ |+ n* s; Lclear all
& I( U: }* |. J0 Y0 e%图论最短路问题的Dijkstra算法  A  O( p) H" q' X( c
%邻接矩阵(点与点的关系)
' A: i2 {: l# H$ B) v7 Ww=[0,2,4,inf,inf,inf,inf;  . y. y2 Y! ~5 E1 h$ H- ~
   2,0,inf,3,3,1,inf;
; j5 [& j+ A+ y; h   4,inf,0,2,3,1,inf;                      ! A  D1 U6 D+ {9 {
   inf,3,2,0,inf,inf,1;                    
+ k& P2 p  N$ N0 h  H   inf,3,3,inf,0,inf,3;& _* l" Z) i& l  r# a; o" f4 {
   inf,1,1,inf,inf,0,4;
8 r- u7 w2 J$ V& M# J   inf,inf,inf,1,3,4,0];
1 h* a! G; a, i' H6 En=size(w,1);%记录图中点数' |$ u3 e8 M& M2 _2 a

  o1 P" i7 a1 P7 cfor i=1:n
* @6 r( P! `8 ]3 e: u9 d    l(i)=w(1,i); %为l(v)赋初值
! F, a  u- @8 y1 R2 n& M- b    z(i)=1;      %为z(v)赋初值1; U6 c5 h+ c7 R
end
4 B+ K; L7 m) K# P1 b1 j* _/ F8 L4 g2 A; h8 L/ P( R  b0 F
s=[];            %s集合' [& ^) r, j# r8 d# I: B
s(1)=1;          %s集合的第1个元素为起点
% ?3 e* w5 @* W  m1 v# C5 ]# Pu=s(1);7 P& r( q2 w' t9 U
k=1;             %k记录集合s中点的数量
8 N) T% w6 F% b5 O' R3 Q- i. N- Q2 q% u1 g) I5 p
while k<n       %当集合s未包含所有元素的时候执行循环
# R/ Z4 z/ S7 e1 l$ ]- O0 A    for i=1:n    %更新一遍l(v),z(v)
) N0 o( X* k' ^( u  F& L3 ]        if l(i)>l(u)+w(u,i): p* A8 ^" i  w& r3 k9 d
            l(i)=l(u)+w(u,i);
" _, A( t! M% W9 o. c* i            z(i)=u;  ~" r, n& K3 G9 Z8 l
        end
2 |: ^& `+ H% T$ i    end
  C9 E+ |- w$ |# u% j) ^7 ]9 ]* }# e: e
    %找l(i)中最小的v加入s集合4 k, i& o# ^! o( a
    ll=l;
. Q! N. s9 l+ E9 X( j+ I  M    for i=1:n( x* s7 I% }8 V
        for j=1:k
9 {$ _: `# T9 E2 J% d            if i==s(j)5 x4 }2 D( S* e& r: F! s2 }1 `
                ll(i)=inf; %去除掉已经在s集合中的点! }4 a" O3 b# Z) @# c
            end
! U+ [* I( c! a; V4 a        end& e( [$ f8 W; T& B6 ]. b- L
    end- j. K) _) L5 N3 d0 j* V
    [lv,v]=min(ll); %求最小的l(v)
4 G) o( q1 Z- T+ F# ~    s(k+1)=v;       %加入集合s' e. n* @2 H& `
    u=v;
- e  O, e6 E$ a    k=k+1;5 S8 ~# r  q+ S- Z
end
. s% n" r$ c: b9 [- F! v3 h( G, y2 L
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)9 {# ?+ y: m# H5 p: |1 u' ]
; L( M9 C3 d$ E# {
解释:
" F5 X& @3 C6 ^1 m5 c8 O4 |
3 f; g% }! @. P1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。# Z/ M! i  D% H2 }2 C
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。4 |5 l9 B" z9 X6 a
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。4 G5 `, B+ s4 M7 y( w
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
% Q5 R, [* c" ^; a' I5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
$ N- z: w& |2 K+ ?% b5 [8 N/ K6 e$ ?9 T" a  T+ D
注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
3 x  M2 R  D- K) ~( S
( z( N8 Y8 B3 N4 F0 g6 y
+ m9 L0 j% d& C; T6 e" m0 J' V4 S: D* R4 Q

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-6-22 23:11 , Processed in 0.398954 second(s), 54 queries .

回顶部