《数据结构课程设计》最短路径问题实验报告

  1. 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
  2. 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
  3. 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。

《数据结构课程设计》最短路径问题实验报告

目录

一、概述 0

二、系统分析 0

三、概要设计 (1)

四、详细设计 (5)

4.1建立图的存储结构 (5)

4.2单源最短路径 (6)

4.3任意一对顶点之间的最短路径 (7)

五、运行与测试 (8)

参考文献 (11)

附录 (12)

交通咨询系统设计(最短路径问题)一、概述

在交通网络日益发达的今天,针对人们关心的各种问题,利用计算机建立一个交通咨询系统。在系统中采用图来构造各个城市之间的联系,图中顶点表示城市,边表示各个城市之间的交通关系,所带权值为两个城市间的耗费。这个交通咨询系统可以回答旅客提出的各种问题,例如:如何选择一条路径使得从A城到B城途中中转次数最少;如何选择一条路径使得从A城到B城里程最短;如何选择一条路径使得从A城到B城花费最低等等的一系列问题。

二、系统分析

设计一个交通咨询系统,能咨询从任何一个城市顶点到另一城市顶点之间的最短路径(里程)、最低花费或是最少时间等问题。对于不同的咨询要求,可输入城市间的路程、所需时间或是所需费用等信息。

针对最短路径问题,在本系统中采用图的相关知识,以解决在实际情况中的最短路径问题,本系统中包括了建立图的存储结构、单源最短问题、对任意一对顶点间最短路径问题三个问题,这对以上几个问题采用了迪杰斯特拉算法和弗洛伊德算法。并未本系统设置一人性化的系统提示菜单,方便使用者的使用。

三、概要设计

可以将该系统大致分为三个部分:

①建立交通网络图的存储结构;

②解决单源最短路径问题;

③实现两个城市顶点之间的最短路径问题。

迪杰斯特拉算法流图:

弗洛伊德算法流图:

四、详细设计

4.1建立图的存储结构

定义交通图的存储结构。邻接矩阵是表示图形中顶点之间相邻关系的矩阵。设G=(V,E)是具有n 个顶点的图,则G 的邻接矩阵是具有如下定义的n 阶方阵。

⎪⎩

⎧∞>∈<=,其他情况或或,若0E(G)

V ,V )V ,(V ],[j i j i ij W j i A 注:一个图的邻接矩阵表示是唯一的!其表示需要用一个二维数组存储顶点之间相邻关系的邻接矩阵并且还需要用一个具有n 个元素的一维数组来存储顶点信息(下标为i 的元素存储顶点i V 的信息)。 邻接矩阵的存储结构:

#define MVNum 100 //最大顶点数 typedef struct {

VertexType vexs[MVNum];//顶点数组,类型假定为char 型 Adjmatrix arcs[MVNum][MVNum];//邻接矩阵,假定为int 型 }MGraph;

注:由于有向图的邻接矩阵是不对称的,故程序运行时只需要输入所有有向边及其权值即可。

4.2单源最短路径

单源最短路径问题:已知有向图(带权),期望找出从某个源点S ∈V到G中其余各顶点的最短路径。

迪杰斯特拉算法即按路径长度递增产生诸顶点的最短路径算法。

算法思想:设有向图G=(V,E),其中V={1,2,……n},cost是表示G的邻接矩阵,

cost[i][j]表示有向边的权。若不存在有向边,则cost[i][j] 的权为无穷大(这里取值为32767)。设S是一个集合,集合中一个元素表示一个顶点,从源点到这些顶点的最短距离已经求出。设顶点V1为源点,集合S的初态只包含顶点V1。数组dist记录从源点到其它各顶点当前的最短距离,其初值为dist[i]= cost[i][j],i=2,……n。从S之外的顶点集合V-S中选出一个顶点w,使dist[w] 的值最小。于是从源点到达w只通过S中的顶点,把w加入集合S中,调整dist中记录的从源点到V-S中每个顶点v的距离:从原来的dist[v]和dist[w]+cost[w][v]中选择较小的值作为新的dist[v]。重复上述过程,直到S中包含V中其余顶点的最短路径。

最终结果是:S记录了从源点到该顶点存在最短路径的顶点集合,数组dist记录了从源点到V中其余各顶点之间的最短路径,path 是最短路径的路径数组,其中path[i]表示从源点到顶点i之间的最短路径的前驱顶点。

4.3任意一对顶点之间的最短路径

任意顶点对之间的最短路径问题,是对于给定的有向网络图G=(V,E),要对G中任意一对顶点有序对,“V,W(V≠W)”,找出V到W 的最短路径。而要解决这个问题,可以依次把有向网络图中每个顶点作为源点,重复执行前面的迪杰斯特拉算法n次,即可求得每对之间的最短路径。

费洛伊德算法的基本思想:假设求从V i到V j的最短路径。如果存在一条长度为arcs[i][j]的路径,该路径不一定是最短路径,还需要进行n次试探。首先考虑路径是否存在。如果存在,则比较路径的路径长度,取长度较短者为当前所求得。该路径是中间顶点序号不大于1的最短路径。其次,考虑从v i到v j是否包含有顶点v2为中间顶点的路径< v i,…,v2,…,v j>,若没有,则说明从v i到v j的当前最短路径就是前一步求出的;若有,那么可分解为,而这两条路径是前一次找到的中间点序号不大于1的最短路径,将这两条路径长度相加就得到路径的长度。将该长度与前一次中求得的从v i到v j的中间顶点序号不大于1的最短路径比较,取其长度较短者作为当前求得的从v i到v j的中间顶点序号不大于2的最短路径。依此类推……直至顶点v n加入当前从v i到v j的最短路径后,选出从v i到v j的中间顶点序号不大于n的最短路径为止。由于图G中顶点序号不大于n,所以v i到v j的中间顶点序号不大于n的最短路径,已考虑了所有顶点作为中间顶点的可能性,因此,它就是v i到v j的最短

相关文档
最新文档