QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1185

主题

4

听众

2919

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |正序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:' k! L  l: w+ w4 j/ a
clear all9 i1 ~( Y1 R2 p
%图论最短路问题的Dijkstra算法( B$ B) V6 g1 J
%邻接矩阵(点与点的关系)
' l6 B' c# i7 }  Ww=[0,2,4,inf,inf,inf,inf;  
/ k1 n5 l, p% i8 q) S! I   2,0,inf,3,3,1,inf;
9 F* ]! V, c* M- j# s+ H   4,inf,0,2,3,1,inf;                      9 p0 A1 o7 _. f
   inf,3,2,0,inf,inf,1;                    . n. D; n. ^& H$ l) ~, i, Y
   inf,3,3,inf,0,inf,3;% z# t* d6 K% g
   inf,1,1,inf,inf,0,4;: p  Y' q* u% I4 z  {* S
   inf,inf,inf,1,3,4,0];
) J$ o0 T+ z( H3 x3 Un=size(w,1);%记录图中点数
4 C! J5 @5 u4 u( u' @+ i- ^
$ ?2 ]7 F9 j) \" E0 }* N1 xfor i=1:n
4 D- X7 t- P! I% f1 k1 ?    l(i)=w(1,i); %为l(v)赋初值# m6 S' {3 J0 q5 |* n' y# W
    z(i)=1;      %为z(v)赋初值12 F2 M& m1 a. T: q5 E
end) _# y7 v) R0 y7 G& \
- i+ c# i  Y$ n3 t7 s" h& E, [
s=[];            %s集合
5 ]$ a3 R1 l- D  r3 _, P$ U3 ms(1)=1;          %s集合的第1个元素为起点& Y7 u' d+ W( U  q
u=s(1);% \: j# i4 w/ S# ?
k=1;             %k记录集合s中点的数量
# q( t, R& S/ t0 t: w! Q2 {4 C- m( r6 R: u0 b% {) d7 @* c
while k<n       %当集合s未包含所有元素的时候执行循环$ R2 L- `9 ~2 t  D8 P7 a: y+ I
    for i=1:n    %更新一遍l(v),z(v)7 k& D4 s  F7 a
        if l(i)>l(u)+w(u,i)( M" x" N) F1 R( a! J& x2 y; c
            l(i)=l(u)+w(u,i);
# Y  R6 O8 E2 ~            z(i)=u;
  `- n( s, U3 S3 u        end
+ S; Z3 D0 ^+ ^5 x! y2 ^    end" M5 C1 Y3 m  }0 x2 K
: V) X: }) Y6 \' j
    %找l(i)中最小的v加入s集合
7 j  x- e' ?. ?    ll=l;3 E) t! q% p' Z0 Y
    for i=1:n6 j9 S2 m. a5 P7 H9 }, f$ c3 y
        for j=1:k" q) n  [$ \* L# i" ?
            if i==s(j)! Y5 n: Z" i/ P& [  e
                ll(i)=inf; %去除掉已经在s集合中的点
; m' t8 \3 W7 E. i* V2 _$ W            end . L: U, [) S+ |# `; A1 }: e
        end
) P% s1 [$ d3 C% a1 ~$ {- x* u    end/ d: {! j6 e6 j) k3 Y
    [lv,v]=min(ll); %求最小的l(v)2 {, f7 V) g$ V! `0 ^+ s; I
    s(k+1)=v;       %加入集合s
& C% ?1 i; \# u! o( ^8 B; e* u    u=v;( l( i; H3 I8 j  C1 A
    k=k+1;5 U7 I. a' U! q! r3 j4 ^# Y
end
- Z! o0 [; |, y; K/ @  h* W! Y& v* p9 P8 W% W2 ?
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
/ t! l* N6 E7 |$ \* \' m) \1 \, u2 V* V( K5 Y3 j
解释:
# b" ^1 r+ Y6 o' T6 S
6 g9 c7 p( x( k9 H4 e: p* i1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。! p5 k, D! t) w6 y9 O. n
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。( a9 S" s* n* m
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。6 V- f( Y9 }( m: O: _  ]
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。% a6 X% c* r! y* o5 `% S6 X
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。0 V5 U1 s2 E+ U0 g

/ ]+ P6 f( {: x+ o注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
( P, F8 P9 r% ]# M$ c1 D# W' u: C' M( H8 m( X4 L# e

! y  E/ z) I# t7 p4 e$ ~

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-1-12 03:51 , Processed in 0.720441 second(s), 55 queries .

回顶部