下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
(Floyd)算法求Vi到Vj的最短路径如果cost[i,j]<>max,从Vi到Vj存在一条长度为cost[i,j]的路径,但该路径不一定是最短路径,尚需进行n次试探。设具有n个顶点的一个带权图G的邻接矩阵用GA表示,再设一个与GA同类型的表示每对顶点之间的最短路径长度的二维数组A,A的初值等于GA。Floyed算法需要在A上进行n次运算,每次以vk(1≤k≤n)作为新考虑的中间点,求出每对顶点之间的当前最短路径长度,最后依次运算后,A中的每个元素A[i,j]就是图G中从顶点vi到vj的最短路径长度。再设一个二维数组P[1..n,1..n],记录最短路径,其元素类型为集合类型set
of
1..n。2、任意一对顶点之间的最短路径(FLOYED);首先,考虑路径(Vi,V1,Vj)是否存在(即判别弧(Vi,V1)和(V1,Vj)是否存在)。如果存在,则比较(Vi,Vj)与(Vi,V1,Vj)的路径长度较短者为从Vi到Vj的中间顶点的序号不大于1的最短路径。在路径上再增加一个顶点V2,也就是说,如果(Vi,…,V2)和(V2,…,Vj)分别是当前找到的中间顶点不大于1的最短路径,那么(
Vi,…,V2,…,Vj)就有可能是Vi到Vj的中间顶点的序号不大于2的最短路径。将它和中间顶点不大于1的最短路径
相比较,从中选出中间顶点不大于2的最短路径。再增加顶点V3,继续进行试探,依此类推,直到经过n次比较后,最后求得Vi到Vj的中间顶点的序号不大于n的最短路径。Procedure
floyed(GA,A,P);beginfor
I:=
1
to
n
doforj:=1
to
ndobeginA[I,j]:=GA[I,j];if
A[I,j]<
maxint
thenp[I,j]:=[I]+[j]elsep[I,j]:=[
];End;fork:=
1to
nd0for
I:=1
to
n
doforj:=
1tondobeginif
(I=k)or
(j=k)or
(I=j)
then
continue;{无需计算,直接进入下一轮if
A[I,k]+A[k,j]<A[I,J]
then
begin
{找到更短路径保存}A[I,J]:=A[I,K]+A[K,J];P[I,J]:=P[I,K]+P[K,J];END;END;END;{最短路径长度数组和最短路径数组初始化}fork:=1
tondofori:=1
tondoforj:=1
tondoif
leng[i,k]+leng[k,j]<leng[i,j]
thenbegin
leng[i,j]:=leng[i,k]+leng[k,j];path[i,j]:=path[i,k]+copy(path[k,j],2,length(path[k,j])-1);end;例1、平面上有n个点(n<=100)每个点的坐标均在-10000~10000之间.其中的一些点之间有连线。若有连线,则表示可以从一个点到达另一个点,即两点间有通路,通路的距离为两点间的直线距离。现在的任务是找出从一点到另一点之间的最短路径。输入:输入文件为short.in,共n+m+3行,其中:第一行为整数n。第二行到n+1行(共n行),每行两个整数x和y,描述了一个点的坐标(以一个空格分隔)。第n+2行为一个整数m,表示图中连线的个数。此后的m行,每行描述一条连线,由两个整数I和j组成,表示第I个点和j个点之间有连线。最后一行:两个整数s和t,分别表示与源点和目标点。输出:输出文件为short.out,仅一行,一个实数(保留两位小数),表示从s到t的最短路径长度。样例输入5002022023515样例输出3.41program
t1(input,output);typepoint=recordx,y:integer;end;var
g:array[1..100,1..100]
ofreal;pos:array[1..100]
ofpoint;n,m,x,y,i,j,k,s,t:integer;
function
dist(i,j:integer):real;begindist:=sqrt(sqr(pos[i].x-pos[j].x)+sqr(pos[i].y-pos[j].y))end;beginassign(input,'short.in');reset(input);assign(output,'short.out')rewrite(output);readln(n);for
i:=
1ton
doreadln(pos[i].x,pos[i].y);for
i:=
1ton
dofor
j:=1
tondog[i,j]:=1e30;readln(m);for
i:=1
to
m
dobeginreadln(x,y);g[x,y]:=dist(x,y);g[y,x]:=g[x,y]end;readln(s,t);for
k:=1
ton
dofori:=1tondoif
i<>k
thenfor
j:=1
ton
doif
(i<>j)and(k<>j)and(g[i,k]<g[i,j])theng[i,j]:=g[i,k]+g[k,j];wri
n(g[s,t]:0:2);close(input);close(output);end.Floyed算法的思想可用于判断有向图中任意两点是否连通?算法如下:For
k:=
1
to
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度全流程代理记账服务合同范本2篇
- 2025玉器采购合同供销合同
- 2025年度房屋抵押借款合同之延期还款及罚息协议范本3篇
- 语文-口语交际-应聘-课件
- 二零二五年广告行业兼职策划合同范本
- 动脉穿刺抽血法操作并发症课件
- 二零二五年度国际海洋运输合同附加货物保险险别规定2篇
- 二零二五年度二手车经销商培训与支持服务合同3篇
- 《小学生脑筋急转弯》课件
- 二零二五年度个人旅游贷款担保服务合同范本2篇
- 《小学生良好书写习惯培养的研究》中期报告
- 大学英语四级词汇表(下载)
- 2025年四川成都市温江区市场监督管理局选聘编外专业技术人员20人历年管理单位笔试遴选500模拟题附带答案详解
- 手术室发生地震应急预案演练
- 初中数学新课程标准(2024年版)
- 高职院校专业教师数字素养架构与提升路径
- 售后服务人员培训资料课件
- 2024-2030年中国薯条行业发展趋势及投资盈利预测报告
- 生命智能学习通超星期末考试答案章节答案2024年
- 专项14-因式分解-专题训练(50道)
- 中华传统文化之戏曲瑰宝学习通超星期末考试答案章节答案2024年
评论
0/150
提交评论