数学建模社区-数学中国
标题:
图中最短路径解决方法 Dijkstra
[打印本页]
作者:
2744557306
时间:
2023-12-22 11:02
标题:
图中最短路径解决方法 Dijkstra
这段代码是Dijkstra算法的一个实现,用于在带权图中找到从一个起始点到其他所有点的最短路径。下面是对代码的逐步解释:
+ i9 O" a9 d0 \$ C8 p
clear all
% l( A) Z `+ I: O- H( Z% U
%图论最短路问题的Dijkstra算法
% z/ _. S% f! @0 s
%邻接矩阵(点与点的关系)
$ l) f: z8 n k2 s
w=[0,2,4,inf,inf,inf,inf;
& p$ x8 K) N1 m$ I$ h9 Q# K4 b
2,0,inf,3,3,1,inf;
, m' d2 j3 X' _3 G8 ^6 v; z3 X! L4 R
4,inf,0,2,3,1,inf;
1 W! S7 O8 ?' R$ @
inf,3,2,0,inf,inf,1;
`. ]5 A: g1 ]
inf,3,3,inf,0,inf,3;
- N& T" N6 g2 A b* I
inf,1,1,inf,inf,0,4;
- c4 S5 d2 j9 _& L+ z( M- b2 N
inf,inf,inf,1,3,4,0];
6 s& ]" |8 _7 X/ ^: p% f( V0 f) c
n=size(w,1);%记录图中点数
, A/ E8 w5 J% b) {
. O) o; J* {5 k7 i' p9 f
for i=1:n
3 ?+ s# U+ _. T6 h0 T
l(i)=w(1,i); %为l(v)赋初值
, S: u( [1 o6 X3 L9 Y# D1 A$ v+ ^
z(i)=1; %为z(v)赋初值1
2 G8 | l* b1 N" q
end
2 e7 W- i; f- k- h
7 ^9 H% Z% d4 J1 _7 [1 q+ x
s=[]; %s集合
# F6 a) M2 C1 x) s) |: b
s(1)=1; %s集合的第1个元素为起点
m1 z$ K. J' @6 I
u=s(1);
' C# D6 ^$ U3 N% A# L# g
k=1; %k记录集合s中点的数量
3 J- ?4 o: S( K
+ C; m9 V9 f% x! u/ q
while k<n %当集合s未包含所有元素的时候执行循环
" T6 X/ p4 m6 k8 U# {' i
for i=1:n %更新一遍l(v),z(v)
6 B' d4 ?- b W
if l(i)>l(u)+w(u,i)
! q+ o4 `1 d# K n! t/ f9 p
l(i)=l(u)+w(u,i);
& M9 L: l0 z( s9 H! M) K* H' M
z(i)=u;
7 P9 @: p9 L/ R3 a) h
end
: Q( a" x5 w$ x$ w7 Q! l
end
6 k% a" C& f1 u) R- ^1 a# S
( Y; P; r5 [, i9 N$ E
%找l(i)中最小的v加入s集合
" f# b$ ~4 V, A" m# i
ll=l;
3 q, {. c0 o& b+ v' E
for i=1:n
" c0 u+ z" O: M1 E+ S& g
for j=1:k
2 _# r; I$ L4 M& ?. \+ d/ a( f: f
if i==s(j)
( S6 b7 @/ n" T/ C: H8 v! N
ll(i)=inf; %去除掉已经在s集合中的点
$ c0 S7 k/ u/ [ v( w$ O
end
6 O# D! s! Z* y+ Y9 X8 J+ }* R
end
4 W" r+ J7 r( v- h9 d& N1 T2 y
end
- v5 S* | I+ u6 r5 k$ D& A8 K
[lv,v]=min(ll); %求最小的l(v)
2 p% y) x. j( G* H+ t) @
s(k+1)=v; %加入集合s
, _& i/ x6 @, e+ s8 ]' D4 C
u=v;
# v- b$ w* n/ {+ V% e2 P
k=k+1;
7 ]2 U8 @) o: I/ P6 X1 ^- E6 W
end
. g5 Y9 {, v. P, V8 ~% B& O
6 h' u' ~" ?8 d; ^( ?
fprintf('最短路为:%1d->%1d->%1d->%1d\n',z(z(z(7))),z(z(7)),z(7),7)
6 [6 q% ~; f" N6 N# m) B5 a
# L$ C" q, E" [3 N! b
解释:
0 H% ^% j( r- f! Z5 i M4 e
% P- N0 U3 l6 @
1.清除变量: clear all 语句清除所有之前定义的变量,以确保从干净的状态开始执行程序。
) ?7 J$ B" n: e. Z" r3 N
2.邻接矩阵: 图被表示为邻接矩阵 w,其中 w(i, j) 表示从顶点 i 到顶点 j 的边的权重。 inf 表示没有直接的边。
9 Z' T; t# E1 W2 {
3.初始化: l 数组存储从起始点到每个点的当前最短路径长度,z 数组存储路径中的前一个顶点。初始时,将起始点到每个点的距离初始化,并将前一个顶点初始化为起始点。
# C1 N6 S+ B# l, {
4.主循环: 使用 while 循环,每次选择一个新的顶点加入集合 s,直到 s 包含所有顶点。在每次循环中,通过更新 l 和 z 数组来逐步找到最短路径。
; g8 i) U0 T8 F7 G! P
5.输出: 最后,使用 fprintf 打印从起始点到指定点的最短路径。在这里,路径是通过回溯 z 数组得到的。
' {) q1 M9 c9 n
) A. w/ `/ k1 e" e3 l5 h
注意:这段代码的输出是针对特定的终点(顶点7)进行的,你可能需要根据你的需求更改这个值。
# ]7 {9 b: _# [3 k
5 k/ @* j2 q: x# y" v' h, j
) l+ p) P. m8 C' p. J
Dijkstra.m
2023-12-22 11:01 上传
点击文件名下载附件
下载积分: 体力 -2 点
913 Bytes, 下载次数: 0, 下载积分: 体力 -2 点
售价:
1 点体力
[
记录
] [
购买
]
欢迎光临 数学建模社区-数学中国 (http://www.madio.net/)
Powered by Discuz! X2.5