- 53
- 0
- 约4.41千字
- 约 8页
- 2019-09-04 发布于湖南
- 举报
最短路问题及其算法
一.实验目的:
1、了解与掌握图论的基本概念、相关MATLAB知识和最短路径算法;
2、学会使用MATLAB编写Dijkstra算法和Floyd算法程序求最短路径.
二.实验内容:
要铺设一条A1→A2→…→A15的输送天然气的主管道,如图所示.经筛选后可以生产这种主管道的钢厂有S1,S2,…,S7.图中粗线表示铁路,单细线表示公路,双细线表示要铺设的管道(假设沿管道或者原来有公路,或者建有施工公路),圆圈表示火车站,每段铁路、公路和管道旁的阿拉伯数字表示里程(单位:km).
为方便计,1km主管道钢管称为1单位钢管.
一个钢厂如果承担制造这种钢管,至少需要生产500单位钢厂在指定期限内能生产刚钢管的最大数量为个单位.钢管出厂销价1单位钢管为万元,如下表:
1
2
3
4
5
6
7
800
800
1000
2000
2000
2000
3000
160
155
155
160
155
150
160
1单位钢管的铁路运价如下表:
里程(km)
300
301-350
351-400
401-450
451-500
运价(万元)
20
23
26
29
32
里程(km)
501-600
601-700
701-800
801-900
901-1000
运价(万元)
37
44
50
55
60
1000km以上每增加1至100km运价增加5万元.
公路运输费用为1单位钢管0.1万元每千米(不足整千米部分按整千米计算).
假设从钢厂订购钢管运输到铺设地点和.钢厂在指定期间内能生产该钢管的最大数量为个单位,钢管出厂销价1单位钢管为155万元.
试制定一个从钢厂到铺设地点和的钢管的订购与运输计划,使总费用最小.
三. 模型建立
设为,将上图按从上到下,从右到左的顺序依次命名如下.将上图改为如下赋权图形:
利用Dijkstra算法和Floyd算法:求中从顶点到其余顶点的最短路.而求钢厂到铺设地点和的最短距离,即为到和的最短距离
解:先写出带权邻接矩阵:
后分别用Dijkstra算法和Floyd算法步骤,求出到和的最短路的权以及的父亲点标记.
四. 模型求解(含经调试后正确的源程序)
(1) Dijkstra算法
road1.m文件源程序:
w=[0 1200 inf inf inf inf inf inf inf inf;
1200 0 12 202 inf inf inf inf inf inf;
inf 12 0 inf 201 inf inf inf inf inf;
inf 202 inf 0 31 20 inf inf inf inf;
inf inf 201 31 0 10 inf 205 inf inf;
inf inf inf 20 10 0 195 inf inf inf;
inf inf inf inf inf 195 0 5 306 inf;
inf inf inf inf 205 inf 5 0 inf 194;
inf inf inf inf inf inf 306 inf 0 10;
inf inf inf inf inf inf inf 194 10 0];
n=size(w,1);
w1=w(1,:);
for i=1:n
l(i)=w1(i);
z(i)=1;
end
s=[];
s(1)=1;
u=s(1);
k=1;
l;
z;
while kn
for i=1:n
for j=1:k
if i~=s(j)
if l(i)l(u)+w(u,i);
l(i)=l(u)+w(u,i);
z(i)=u;
end
end
end
end
l;
z;
ll=l;
for i=1:n
for j=1:k
if i~=s(j)
ll(i)=ll(i);
else
ll(i)=inf;
end
end
end
lv=inf;
for i=1:n
if ll(i)lv
lv=ll(i);
v=i;
end
end
lv;
v;
s(k+1)=v;
k=k+1;
u=s(k);
end
l
z
(2) Floyd算法
road2.m文件源程序:
a=[0 1200 inf inf inf inf inf inf inf inf;
1200 0 12 202 inf inf inf inf inf inf;
inf 12 0 inf 201 inf inf inf inf inf;
inf 202 inf 0
原创力文档

文档评论(0)