QQ登录

只需要一步,快速开始

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

图中最短路径解决方法 Dijkstra

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

1186

主题

4

听众

2922

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2023-12-22 11:02 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:" h$ x+ M* z  f: S
clear all* D: [) I5 I# K- U2 p
%图论最短路问题的Dijkstra算法
5 V& H/ a- a6 a; N! t1 f4 F%邻接矩阵(点与点的关系)
4 a- Q6 U, ~+ ?' D; w: cw=[0,2,4,inf,inf,inf,inf;  3 K# l. R, _% m
   2,0,inf,3,3,1,inf;" u$ c( Y: L3 P) v4 \9 M# N, ]
   4,inf,0,2,3,1,inf;                     
( ], l4 }4 q; T   inf,3,2,0,inf,inf,1;                    
6 g, Q: p: x2 o" K0 J; i/ m) v   inf,3,3,inf,0,inf,3;  Q, a8 f% d* b/ |- _* g5 h3 R
   inf,1,1,inf,inf,0,4;
# x, P- e; J; g6 l   inf,inf,inf,1,3,4,0];
" [. I  e0 W9 o& d  ?n=size(w,1);%记录图中点数# M1 p1 e9 _: l+ ?

" x1 J$ i8 n- ^9 Y8 d. R7 Ffor i=1:n
2 N" y/ f# v: U    l(i)=w(1,i); %为l(v)赋初值
8 a9 Q& ~# p0 R# i; |3 K    z(i)=1;      %为z(v)赋初值1
* n. v. U! L, p8 ]8 Cend
: {, a* S# k0 Q, I$ z) u. X6 F; G$ x' o" K( H: y5 @1 v
s=[];            %s集合
* m& y+ c6 N7 c& D# X# V0 M8 ls(1)=1;          %s集合的第1个元素为起点
  T( i# H8 f, k" i6 pu=s(1);
$ z) N  k" g. S% g, |8 z9 v; \k=1;             %k记录集合s中点的数量) k0 h% C" S: r8 {. g7 t0 y, C) l
5 J+ S# f% b6 a. p" ]6 k4 ^/ o
while k<n       %当集合s未包含所有元素的时候执行循环; t- H8 L# f5 ]  E) s3 m$ i
    for i=1:n    %更新一遍l(v),z(v)+ q8 C' q" u$ ?2 B/ W8 }
        if l(i)>l(u)+w(u,i)- E/ a* T8 ^. c( h4 z3 T* r7 ?' \' Z
            l(i)=l(u)+w(u,i);) _" Q. b  m; F0 P# f! A, H
            z(i)=u;# p% c4 T( o8 v. P! c: m
        end3 f/ V2 {( I8 ?1 A# r
    end% I+ |  a$ x2 o( b1 n! j

7 w6 A: K, W& r5 R    %找l(i)中最小的v加入s集合& U$ R+ }* G/ h! u& [2 y
    ll=l;7 B3 H7 p. K5 G1 j9 Z: H( ?9 q/ t
    for i=1:n
& E$ K) {& [% }7 i        for j=1:k
* f8 o& q5 }9 \' o# p# p            if i==s(j): b& o5 g6 Z/ O3 h# N, X4 c1 O  z2 K& N
                ll(i)=inf; %去除掉已经在s集合中的点5 W2 l' Z! q  Q
            end
* i) Q' q% G4 B3 r% x        end
& }5 i9 r( i1 ^% u% ?& J7 R    end
- S0 i* r$ p( C! {8 b; J' ]; T0 w8 X! J    [lv,v]=min(ll); %求最小的l(v)( A2 V( S1 C( r3 P9 O5 a5 j
    s(k+1)=v;       %加入集合s/ I9 c* w( O( q3 y7 n8 [
    u=v;2 f; @' C3 ^4 Z1 S- w, y0 G
    k=k+1;
: `1 F6 p& ?% v; u8 ]. m% ~end
: n8 N  F; Z  D1 H! X5 G
/ C* |+ {' a2 qfprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)# ^1 _5 S& Q) {3 @4 Q, i
: S) ]  C, H9 \; p1 X
解释:
+ S3 a; U" I% t$ B1 S8 l& K- r& T% `' j0 Q
1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。7 z8 C; C' x" B9 B* a7 @: u
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。( o6 _' ]2 E: O. }' a, R) j- T
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。4 [- w) Q5 {: \
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。: i% Q1 j0 v" R' r8 B
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。7 k3 P. B+ C% e

. ~& _" |% n; M: i$ C3 d0 {) g3 g& c注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。$ r+ `. ?/ M) o

$ L" d) I* U. {  A& b9 i+ Y' a0 m  k. f9 B; v9 G8 {8 ~

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 05:34 , Processed in 0.434555 second(s), 55 queries .

回顶部