交通咨询系统数据结构c语言Word版_第1页
交通咨询系统数据结构c语言Word版_第2页
交通咨询系统数据结构c语言Word版_第3页
交通咨询系统数据结构c语言Word版_第4页
交通咨询系统数据结构c语言Word版_第5页
已阅读5页,还剩13页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、传播优秀Word版文档 ,希望对您有帮助,可双击去除!数 据 结 构 课 程 设 计交通咨询系统设计学 生 姓 名: 学 号: 指 导 教 师: 完 成 日 期: 传播优秀Word版文档 ,希望对您有帮助,可双击去除!目 录1 设计任务书11.1 题目与要求11.2 知识点11.3 输入输出分析11.4 实现的功能12 概要设计22.1 结构体类型及函数声明22.2 主程序流程23 详细设计33.1 数据类型实现33.2 程序代码34 调试分析104.1 问题分析与回顾104.2 算法时空分析114.3 算法改进114.4 经验和体会115 测试结果12参考文献14传播优秀Word版文档 ,希

2、望对您有帮助,可双击去除!1 设计任务书1.1 题目与要求题目:编写程序实现交通咨询系统设计的模拟。要求:(1)建立交通网络网的存储结构; (2)总体设计要画流程图; (3)提供程序测试方案;(4)界面友好。1.2 知识点本次课程设计应用到了图的创建、邻接矩阵、迪杰斯特拉算法、弗洛伊德算法、结构体、宏定义、自定义类型、函数的声明与调用等知识点。1.3 输入输出分析(1)普通输入对于图的存储,我采用的是邻接矩阵的方法,借助于邻接矩阵容易判定任意两个顶点之间是否有弧相连,也容易求得各段弧的权值。 (2)对话式输入在用户选择系统功能时,我采用的是对话式输入,让用户输入系统功能的代号,利用switch

3、语句判断用户输入的指令并调用相应的函数实现具体功能。(3)程序输出对于用户查询结果的展示,考虑美观以及方便用户的因素,我写了一个pri()函数输出各个城市的代码城市名字对照表,用户可以更方便的使用。对于用户查询一个城市到所有城市的最短路径时,考虑到显示结果较多,我采用表格的形式进行显示,使界面更美观。1.4 实现的功能在交通网络越来越发达的今天,人们出去旅行、出差更多的会考虑选择最短路径或最小花费等问题,因此我设计了一个交通咨询系统。这个系统可以根据用户的选择实现3种功能:求一个城市到所有城市的最短路径;求两个城市间的最短路径;求两个城市间的最小花费。传播优秀Word版文档 ,希望对您有帮助,

4、可双击去除!2 概要设计2.1 结构体类型及函数声明(1)结构体路径图结构体类型 MGraph 花费图结构体类型 HGraph (2)函数声明void pri() /输出城市代号对照表函数。void CreateMGraph(MGraph *G) /创建路径图函数,路径图存放于G中。void CreateHGraph(HGraph *H) /创建花费图函数,花费图存放于H中。void Dijkstra(MGraph *G, int v1,int n) /迪杰斯特拉算法求单源最短路径函数,v1为源点,n为城市个数,这个图存放于G中。void Floyd(MGraph *G, int n) /弗洛

5、伊德求两点间最短路径函数,n表示城市个数,这个图存放于G中。void Floyd1(HGraph *H, int n) /弗洛伊德求两点间最小花费函数,n表示城市个数,这个图存放于H中。2.2 主程序流程(1)主程序调用模块图主程序利用switch()语句实现各个模块的调用,主函数调用如图2-1所示。 主程序根据不同值主调函数0退出1求单源最短路径2求两点间最短路径3求两点间最小花费图2-1 主程序调用模块图传播优秀Word版文档 ,希望对您有帮助,可双击去除!3 详细设计3.1 数据类型实现 (1)路径图结构体类型 Vertextype vexsMVNum; /顶点数组,顶点表示城市代号 A

6、djmatrix arcsMVNum MVNum; /邻接矩阵定义路径图 MGraph;(2)花费图结构体类型typedef struct Vertextype vexsMVNum; /顶点数组,顶点表示城市代号Adjmatrix arcsMVNum MVNum; /邻接矩阵定义花费图 HGraph;3.2 程序代码 #include #include #define MVNum 100 /最大顶点数 #define Maxint 65535 /定义一个最大数,其意义为无穷大enum booleanFALSE,TRUE; typedef char Vertextype; typedef int

7、 Adjmatrix; typedef struct Vertextype vexsMVNum; /顶点数组 类型假定为char型 Adjmatrix arcsMVNum MVNum; / 邻接矩阵 假定为int型 MGraph; typedef struct Vertextype vexsMVNum; /顶点数组 类型假定为char型 Adjmatrix arcsMVNum MVNum; / 邻接矩阵 假定为int型 HGraph; int D1MVNum, p1MVNum; int DMVNumMVNum,pMVNumMVNum; void pr(int i)switch(i)传播优秀Wo

8、rd版文档 ,希望对您有帮助,可双击去除!case 1:printf(北京 );break;case 2:printf(天津 );break;case 3:printf(郑州 );break;case 4:printf(徐州 );break;case 5:printf(西安 );break;case 6:printf(成都 );break; case 7:printf(武汉 );break;case 8:printf(上海 );break;case 9:printf(福州 );break; case 10:printf(南昌 );break;case 11:printf(株洲 );break;

9、case 12:printf(贵阳 );break; case 13:printf(昆明 );break;case 14:printf(广州 );break;void pri()int i;printf(城市代号对照表n);printf(*);for(i=1;i=14;i+)printf(%d.,i); pr(i); pr(i);printf(n); printf(*);void CreateMGraph(MGraph *G) /采用邻接矩阵表示法构造有向图G,此图为带权距离图 int i,j; for(i=1;ivexsi=(char)i; for(i=1;i=14;i+) for(j=1;

10、jarcsij=Maxint; / 初始化邻接矩阵 G-arcs12=G-arcs21=137; G-arcs24=G-arcs42=674; G-arcs13=G-arcs31=695; G-arcs34=G-arcs43=349;G-arcs35=G-arcs53=511; G-arcs56=G-arcs65=842;G-arcs37=G-arcs73=534; G-arcs48=G-arcs84=651;G-arcs613=G-arcs136=1100; G-arcs612=G-arcs126=967;G-arcs711=G-arcs117=409; G-arcs810=G-arcs10

11、8=825;G-arcs910=G-arcs109=622; G-arcs1011=G-arcs1110=367;G-arcs1112=G-arcs1211=902;G-arcs1213=G-arcs1312=639; G-arcs1114=G-arcs1411=675; void CreateHGraph(HGraph *H) /采用邻接矩阵表示法构造有向图H,此图为带权花费图 int i,j; for(i=1;ivexsi=(char)i; for(i=1;i=14;i+) for(j=1;jarcsij=Maxint; / 初始化邻接矩阵 H-arcs12=H-arcs21=20; H-

12、arcs24=H-arcs42=93; H-arcs13=H-arcs31=93; H-arcs34=H-arcs43=51;H-arcs35=H-arcs53=72; H-arcs56=H-arcs65=112;H-arcs37=H-arcs73=75; H-arcs48=H-arcs84=91;H-arcs613=H-arcs136=141; H-arcs612=H-arcs126=128;H-arcs711=H-arcs117=62; 传播优秀Word版文档 ,希望对您有帮助,可双击去除! H-arcs810=H-arcs108=105;H-arcs910=H-arcs109=86; H

13、-arcs1011=H-arcs1110=53;H-arcs1112=H-arcs1211=115;H-arcs1213=H-arcs1312=86; H-arcs1114=H-arcs1411=91; /以下是迪杰斯特拉算法void Dijkstra(MGraph *G, int v1,int n) /用Dijkstra算法求有向网G的v1顶点到其他顶点v的最短路径Pv及其权Dv /设G是有向图的邻接矩阵,若边不存在则Gij=Maxint /Sv为真当且仅当v属于S,即已经求得从v1到v的最短路径 int DMVNum, P2MVNum; int v,i,w,min; enum boolea

14、n SMVNum; for(v=1;varcsv1v; /置初始的最短路径值 if(Dv Maxint) P2v=v1; /v1是前趋双亲else P2v=0; /v 无前趋 / End_for Dv1=0;Sv1=TRUE; /S集初始时只有源点 源点到源点的距离为0 /开始循环每次求的V1到某个V顶点的最短路径并加V到S集中 for(i=2;i=n;i+)/其余n-1个顶点min=Maxint; / 当前所知离v1顶点的最近距离设初值为 for(w=1;w=n;w+) /对所有顶点检查 if(!Sw & Dwmin) /找离v1最近的顶点w并将其赋给v距离赋给min v=w; /在S集之外

15、的离v1最近的顶点序号 min=Dw; /最近的距离 /W顶点距离V1顶点更近 Sv=TRUE; /将v并入S集 for(w=1;warcsvwarcsvw; /更新D2w P2w=v; 传播优秀Word版文档 ,希望对您有帮助,可双击去除! /End_if /End_for printf (路径长度(单位:km) 最短路径n); for(i=1;i=n;i+) printf (%10d, Di); printf (%13d, i);v=P2i; while(v!=0) printf (-%d, v); v=P2v; printf(n); printf(nn); /以下是弗洛伊德求最短路径算法

16、void Floyd(MGraph *G, int n) /用Floyd算法求有向网G中各对顶点i和j之间的最短路径int i, j, k; for(i=1;i=n;i+) for(j=1;jarcsij!=Maxint) pij=j; /j是i的后继 else pij=0; Dij=G-arcsij; for(k=1;k=n;k+) for(i=1;i=n;i+) for(j=1;j=n;j+) if(Dik+DkjDij) Dij=Dik+Dkj; /修改长度 pij=pik; 传播优秀Word版文档 ,希望对您有帮助,可双击去除!void Floyd1(HGraph *H, int n)

17、 /用Floyd算法求有向网H中各对顶点i和j之间的最小花费int i, j, k; for(i=1;i=n;i+) for(j=1;jarcsij!=Maxint) pij=j; /j是i的后继 else pij=0; Dij=H-arcsij; for(k=1;k=n;k+) for(i=1;i=n;i+) for(j=1;j=n;j+) if(Dik+Dkj%d,k); /输出后继顶点 k=pkw; /继续找下一个后继顶点 printf(-%d,w); / 输出终点w printf( 路径长度:%dnnn,Dvw); break; case 3: pri(); Floyd1(H,14);

18、 /调用费洛伊德求最小花费算法 传播优秀Word版文档 ,希望对您有帮助,可双击去除! printf(输入城市起点代号和终点代号:); scanf(%d%d,&v,&w ); k=pvw; /k为起点v的后继顶点 if(k=0) printf(顶点%d 到 %d 无路径! n,v,w); else printf(从顶点%d到%d的路径是: %d,v,w,v); while(k!=w) printf(-%d,k); /输出后继顶点 k=pkw; /继续找下一个后继顶点 printf(-%d,w); / 输出终点w printf(n最小花费(单位:元):%dnnn,Dvw); break;4 调试

19、分析4.1 问题分析与回顾问题1:求单源最短路径时,两点间无路径时程序出错。分析 对于边的初始化出错,我在程序开始的地方定义了一个最大数Maxint =65535表示无穷大,初始化邻接矩阵时,添加了一句“G-arcsij=Maxint;”。问题2:求两点间最短路径时,程序运行时不能给出最短路径。分析:Floyd函数里修改长度时少写了一层循环,加上之后就好了。问题3:输出城市代码对照表时出错。分析:pri函数中调用pr函数时,pr函数应写到循环里边,我写到了循环外边。4.2 算法时空分析(1)迪杰斯特拉求单源最短路径的算法:对于n个顶点,每次求的V1到某个V顶点的最短路径时,第一个for循环的时

20、间复杂度是O(n),内层for循环的时间复杂度是O(n),所以总的时间复杂度是O(n2)。(2)弗洛伊德求两点间最短路径的算法:传播优秀Word版文档 ,希望对您有帮助,可双击去除!对于n个顶点,循环求最短路径是,第一个for循环时间复杂度是O(n),内层又有两个for循环,其时间复杂度是O(n2),所以总的时间复杂度是O(n3)。(3)弗洛伊德求两点间最小花费的算法:对于n个顶点,此算法和求两点间最短路径算法时间复杂度一样,也是O(n3)。4.3 算法改进在这个交通咨询系统中,创建图时,我是在程序里对图进行了初始化,赋予了一定的权值,这样不利于图的更新和再创建,系统功能还不是很完善。求两点间

21、最短路径和最小花费都用到了弗洛伊德算法,由于我编程的经验不足,对函数参数传递理解的还不够透彻,所以用了两次弗洛伊德算法,这一点上还有待改进。 4.4 经验和体会经过这些天的设计,这个交通咨询系统已经实现。这个设计可以实现用户输入指令,系统进行相应的查询功能。学习数据结构对我后继学习其它课程也有很大的帮助,因为运用数据结构可以编出更“好”的程序。以前学习C语言时,只会编写简单的小程序,对于那些大点的程序,如果不用数据结构,程序就会显得臃肿、杂乱无章。以前只是一味的编程,学了数据结构之后,我明白了程序中的各个部分在计算机中是怎么存储的,明白了怎么编写程序可以降低程序的时空复杂度让程序看起来更有条理

22、。 此次课程设计,给我提供了一个既动手又动脑,独立实践的机会。我回顾了C语言编程的方法和编程的思想,并运用数据结构的知识使程序的时空复杂度都有所降低。这次课程设计让我更深刻地理解了迪杰斯特拉算法和弗洛伊德算法求最短路径的问题,而且在编程的过程中,更加锻炼了我的思维模式,让自己的思维更有条理,写出的程序也更简单明了。课程设计中,我将学到的知识融会贯通,同时提高调试程序的能力,养成良好的编程习惯,并增强对程序整体设计的把握,理论与实践相结合。通过此次课程设计,让我明白了数据结构的重要性,同时也提高了我分析问题、解决问题的能力。我会再接再厉,编写出更好的程序。传播优秀Word版文档 ,希望对您有帮助,可双击去除!5 测试结果(1) 系统运行首页面如图5-1所示:图5-1 系统首页图(2) 选择“1”,系统会给出城市代号对照表并提示用户输入城市起点代号,运行截图如图5-2所示:图5-2 选择“1”功能运行图(3) 输入城市代号“1”,系统会给出“1”到所有城市的最短路径以及路径长度,运行截图如图5-3所示:图5-3 求单源最短路径输出图(4) 选择功能“2”,并输入城市起点和终点代号“1”和“4”,系统会给出最短路径和最短路径长度,运行截图如图5-4所示:传播优秀Word版文档

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论