《数据结构课程设计》最短路径问题实验报告
更新时间:2024-01-30 10:35:01 阅读量: 教育文库 文档下载
- 数据结构课程设计实践报告推荐度:
- 相关推荐
目 录
一、概述 ......................................... 1 二、系统分析 ..................................... 1 三、概要设计 ..................................... 2 四、详细设计 ..................................... 5 4.1建立图的存储结构 ........................... 5 4.2单源最短路径 ............................... 6 4.3任意一对顶点之间的最短路径 ................. 7 五、运行与测试 ................................... 8 参考文献 ........................................ 11 附录 ............................................ 12
交通咨询系统设计(最短路径问题) 一、概述
在交通网络日益发达的今天,针对人们关心的各种问题,利用计
算机建立一个交通咨询系统。在系统中采用图来构造各个城市之间的联系,图中顶点表示城市,边表示各个城市之间的交通关系,所带权值为两个城市间的耗费。这个交通咨询系统可以回答旅客提出的各种问题,例如:如何选择一条路径使得从A城到B城途中中转次数最少;如何选择一条路径使得从A城到B城里程最短;如何选择一条路径使得从A城到B城花费最低等等的一系列问题。
二、系统分析
设计一个交通咨询系统,能咨询从任何一个城市顶点到另一城市顶点之间的最短路径(里程)、最低花费或是最少时间等问题。对于不同的咨询要求,可输入城市间的路程、所需时间或是所需费用等信息。
针对最短路径问题,在本系统中采用图的相关知识,以解决在实际情况中的最短路径问题,本系统中包括了建立图的存储结构、单源最短问题、对任意一对顶点间最短路径问题三个问题,这对以上几个问题采用了迪杰斯特拉算法和弗洛伊德算法。并未本系统设置一人性化的系统提示菜单,方便使用者的使用。
1
三、概要设计
可以将该系统大致分为三个部分:
① 建立交通网络图的存储结构; ② 解决单源最短路径问题;
③ 实现两个城市顶点之间的最短路径问题。
交通咨询系统 建立图的 存储结构 义 迪杰斯特拉算法(单源最短路径) 费洛依德算法(任意顶点对间最短路径)
迪杰斯特拉算法流图:
2
弗洛伊德算法流图:
3
4
四、详细设计
4.1建立图的存储结构
定义交通图的存储结构。邻接矩阵是表示图形中顶点之间相邻关系的矩阵。设G=(V,E)是具有n个顶点的图,则G的邻接矩阵是具有如下定义的n阶方阵。
?Wij,若(Vi,Vj)或?Vi,Vj??E(G)? A[i,j]???0或?,其他情况?注:一个图的邻接矩阵表示是唯一的!其表示需要用一个二维数组存储顶点之间相邻关系的邻接矩阵并且还需要用一个具有n个元素的一维数组来存储顶点信息(下标为i的元素存储顶点Vi的信息)。 邻接矩阵的存储结构:
#define MVNum 100 //最大顶点数 typedef struct {
VertexType vexs[MVNum];//顶点数组,类型假定为char型 Adjmatrix arcs[MVNum][MVNum];//邻接矩阵,假定为int型 }MGraph;
注:由于有向图的邻接矩阵是不对称的,故程序运行时只需要输入所有有向边及其权值即可。
5
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之间的最短路径的前驱顶点。
6
4.3任意一对顶点之间的最短路径
任意顶点对之间的最短路径问题,是对于给定的有向网络图
G=(V,E),要对G中任意一对顶点有序对,“V,W(V≠W)”,找出V到W的最短路径。而要解决这个问题,可以依次把有向网络图中每个顶点作为源点,重复执行前面的迪杰斯特拉算法n次,即可求得每对之间的最短路径。
费洛伊德算法的基本思想:假设求从Vi到Vj的最短路径。如果存在一条长度为arcs[i][j]的路径,该路径不一定是最短路径,还需要进行n次试探。首先考虑路径
7
路径。
五、运行与测试
测试实例1:利用如下图所示的有向图来测试 1 13 3 17 7 61 32 76 74 2 6 64 26 4 56 45 5 测试实例2:利用下图求交通网络图(无向图)的最短路径。 2553 北京 1 西安 704 2 695 812 4 成都 511 3 349 5 郑州 651 1579 2368 1385 7 上海 广州 6
实例1运行结果:
徐州8
9
实例2运行结果:
10
六、总结与心得
该课程设计主要是从日常生活中经常遇到的交通网络问题入手,进而利用计算机去建立一个交通咨询系统,以处理和解决旅客们关心的各种问题(当然此次试验最终主要解决的问题是:最短路径问题)。
这次试验中我深刻的了解到了树在计算机中的应用是如何的神奇与灵活,对于很多的问题我们可以通过树的相关知识来解决,特别是在解决最短路径问题中,显得尤为重要。
经过着次实验,我了解到了关于树的有关算法,如:迪杰斯特拉算法、弗洛伊德算法等,对树的学习有了一个更深的了解。
参考文献
【1】《数据结构》严蔚敏.清华大学出版社. 【2】《数据结构课程设计》苏仕华.极械工业出版社.
11
附录
#include
enum boolean{FALSE,TRUE}; typedef char VertexType; typedef int Adjmatrix; typedef struct{ VertexType vexs[MVNum]; Adjmatrix arcs[MVNum][MVNum]; }MGraph;
int D1[MVNum],p1[MVNum];
int D[MVNum][MVNum],p[MVNum][MVNum]; void CreateMGraph(MGraph * G,int n,int e) { int i,j,k,w; for(i=1;i<=n;i++) G->vexs[i]=(char)i; for(i=1;i<=n;i++) for(j=1;j<=n;j++) G->arcs[i][j]=Maxint; printf(\输入%d条边的i.j及w:\\n\ for(k=1;k<=e;k++){ scanf(\ G->arcs[i][j]=w; } printf(\有向图的存储结构建立完毕!\\n\}
void Dijkstra(MGraph *G,int v1,int n) { int D2[MVNum],p2[MVNum]; int v,i,w,min; enum boolean S[MVNum]; for(v=1;v<=n;v++){ S[v]=FALSE; D2[v]=G->arcs[v1][v]; if(D2[v] 12 p2[v]=0; } D2[v1]=0; S[v1]=TRUE; for(i=2;i void Floyd(MGraph *G,int n) { int i,j,k,v,w; for(i=1;i<=n;i++) for(j=1;j<=n;j++) { if( G->arcs[i][j]!=Maxint) p[i][j]=j; else p[i][j]=0; D[i][j]=G->arcs[i][j]; } for(k=1;k<=n;k++) { for(i=1;i<=n;i++) for(j=1;j<=n;j++) { if(D[i][k]+D[k][j] 13 D[i][j]=D[i][k]+D[k][j]; p[i][j]=p[i][k]; } } } } void main() { MGraph *G; int m,n,e,v,w,k; int xz=1; G=(MGraph *)malloc(sizeof(MGraph)); printf(\输入图中顶点个数和边数n,e:\ scanf(\ CreateMGraph(G,n,e); while(xz!=0){ printf(\求城市之间最短路径************\\n\ printf(\ printf(\求一个城市到所有城市的最短路径\\n\ printf(\求任意的两个城市之间的最短路径\\n\ printf(\ printf(\请选择 :1或2,选择0退出:\\n\ scanf(\ if (xz==2){ Floyd(G,n); printf(\输入源点(或起点)和终点:v,w:\ scanf(\ k=p[v][w]; if (k==0) printf(\顶点%d 到 %d 无路径!\\n\ else { printf(\从顶点%d 到 %d 最短路径路径是:%d\ while (k!=w){ printf(\ k=p[k][w]; } printf(\ printf(\径路长度:%d\\n\ } } else if(xz==1) printf(\求单源路径,输入源点v :\ 14 } scanf(\ Dijkstra(G,v,n); } printf(\结束求最短路径,再见!\\n\ 15
正在阅读:
《数据结构课程设计》最短路径问题实验报告01-30
古墓丽影攻关秘籍 - 图文10-27
《进出口报关实务》电子教案19出口监管仓库、保税物流中心 - 图文09-20
江苏省新沂市第二中学七年级英语上册Unit4Myday期中复习(无答案)(新版)牛津版03-16
议论文写作中学生思辨性思维的培养03-08
WCB-820系列微机厂变保护测控装置技术及使用说明书08-29
公司治理转型的研究(论文初稿)09-18
《光纤通信》教学大纲资料03-08
大学生爱情兵法 期末考试09-28
企业巡察工作个人心得体会03-31
- exercise2
- 铅锌矿详查地质设计 - 图文
- 厨余垃圾、餐厨垃圾堆肥系统设计方案
- 陈明珠开题报告
- 化工原理精选例题
- 政府形象宣传册营销案例
- 小学一至三年级语文阅读专项练习题
- 2014.民诉 期末考试 复习题
- 巅峰智业 - 做好顶层设计对建设城市的重要意义
- (三起)冀教版三年级英语上册Unit4 Lesson24练习题及答案
- 2017年实心轮胎现状及发展趋势分析(目录)
- 基于GIS的农用地定级技术研究定稿
- 2017-2022年中国医疗保健市场调查与市场前景预测报告(目录) - 图文
- 作业
- OFDM技术仿真(MATLAB代码) - 图文
- Android工程师笔试题及答案
- 生命密码联合密码
- 空间地上权若干法律问题探究
- 江苏学业水平测试《机械基础》模拟试题
- 选课走班实施方案
- 数据结构
- 路径
- 课程
- 实验
- 报告
- 问题
- 设计
- 华为手机分析
- 中级分析工试卷2
- 水中军团菌检测(ISO11731-1998)
- 08AP0622-Marian系统用户操作手册(MLCL) - 图文
- 北京市存量房交易结算资金划转协议
- 形容词副词比较级最高级讲解及习题
- 人教版11册数学《分数四则混合运算和应用题复习》练习题
- 电力安全培训监督管理办法
- 现代设计方法作业
- 四 - - 自动控制 - - 根轨迹法2
- 年级物理中考分类复习(作图专题)
- 部编版二年级语文上册第5单元教材分析及单元备课
- 2015年心理学考试题及答案
- 镇远县旅游业发展现状和营销对策研究
- 学校安全管理制度汇编台账(2015年整理)
- 杰出校友选拔评选参考标准
- 数学建模 - 交通管理问题
- 关于纪检监察机关案件审理工作的几个问题
- 西南大学网络学院污物理化学0129答案已整理
- 古希腊神话的论文文档