ImageVerifierCode 换一换
格式:DOCX , 页数:14 ,大小:284.68KB ,
资源ID:10452061      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bdocx.com/down/10452061.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(图的最短路径实现 实验报告.docx)为本站会员(b****8)主动上传,冰豆网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰豆网(发送邮件至service@bdocx.com或直接QQ联系客服),我们立即给予删除!

图的最短路径实现 实验报告.docx

1、图的最短路径实现 实验报告数据结构课程设计报告图的最短路径算法的实现班 级: 计算机112班 姓 名: * 指导教师: * 成 绩:_ 信息工程学院 2013 年 1 月 11 日一、题目描述1.1题目内容设计校园平面图,所含景点不少于8个。以图中顶点表示学校内各景点,存放景点的名称、景点介绍信息等;以边表示路径,存放路径长度信息。要求将这些信息保存在文件graph.txt中,系统执行时所处理的数据要对此文件分别进行读写操作。2.2题目要求1从文件graph.txt中读取相应数据, 创建一个图,使用邻接矩阵表示图 ;2景点信息查询:为来访客人提供校园任意景点相关信息的介绍;3问路查询:为来访客

2、人提供校园任意两个景点之间的一条最短路径 。选做内容:1. 修改一个已有景点的相关信息;2. 增加一个新景点及其相关信息;3. 增加一条新的路径;4. 删除一个景点及其相关信息;5. 删除一条路径。二、设计概要2.1程序的主要功能现实校园主要的经典名称;查询各个经典的信息;更改景点的信息;删除某个景点;2.2数据结构校园道路是双向通行的,可设校园平面图是一个带权的无向图,用邻接矩阵表示此无向网。2.3算法分析Floyd算法又称为弗洛伊德算法,插点法,是一种用于寻找给定的加权图中顶点间最短路径的算法。核心思路通过一个图的权值矩阵求出它的每两点间的最短路径矩阵。从图的带权邻接矩阵A=a(i,j)

3、nn开始,递归地进行n次更新,即由矩阵D(0)=A,按一个公式,构造出矩阵D(1);又用同样地公式由D(1)构造出D(2);最后又用同样的公式由D(n-1)构造出矩阵D(n)。矩阵D(n)的i行j列元素便是i号顶点到j号顶点的最短路径长度,称D(n)为图的距离矩阵,同时还可引入一个后继节点矩阵path来记录两点间的最短路径。采用的是松弛技术,对在i和j之间的所有其他点进行一次松弛。算法描述a)初始化:Du,v=Au,vb)For k:=1 to nFor i:=1 to nFor j:=1 to nIf Di,jDi,k+Dk,j ThenDi,j:=Di,k+Dk,j;c)算法结束:D即为所

4、有点对的最短路径矩阵算法过程把图用邻接矩阵G表示出来,如果从Vi到Vj有路可达,则Gi,j=d,d表示该路的长度;否则Gi,j=空值。定义一个矩阵D用来记录所插入点的信息,Di,j表示从Vi到Vj需要经过的点,初始化Di,j=j。把各个顶点插入图中,比较插点后的距离与原来的距离,Gi,j = min( Gi,j, Gi,k+Gk,j ),如果Gi,j的值变小,则Di,j=k。在G中包含有两点之间最短道路的信息,而在D中则包含了最短通路径的信息。比如,要寻找从V5到V1的路径。根据D,假如D(5,1)=3则说明从V5到V1经过V3,路径为V5,V3,V1,如果D(5,3)=3,说明V5与V3直接

5、相连,如果D(3,1)=1,说明V3与V1直接相连。三、设计图示 四、详细设计void creat()/从文件中读取景点信息 ifstream inFile; inFile.open(graph.txt); int flag=0; while(inFilenm) for(int i=1;itmp; gtmp=i; pointi.name=tmp; inFilepointi.intro; for(int i=0;iuv; inFilekey; Mapgugv=Mapgvgu=key; inFile.close();void search()/查找任意两点间的最短路径 int s,t; for(i

6、nt i=1;i=n;i+) for(int j=1;j=n;j+) if(i!=j) if(Mapij=0) gmij=INF; else gmij=Mapij; else gmij=INF; for(int i=1;i=n;i+) for(int j=1;j=n;j+) pathij=i; for(int k=1;k=n;k+) for(int i=1;i=n;i+) for(int j=1;jgmik+gmkj) gmij = gmik+gmkj; pathij=pathkj; while(1) system(cls); menu(); while(1) printf(请输入起点: );

7、 int tmp; cintmp; s=tmp; printf(请输入终点:); cintmp; t=tmp; if(sn|tn) printf(nn输入错误!请重新输入!nn); else break; int mpathMAX; int cnt=0; int p=t; while(p!=s) mpathcnt+=p; p=pathsp; mpathcnt+=s; if(gmst=INF) printf(没有直达路径!n); else printf(n最短路径为:); for(int i=cnt-1;i=1;i-) coutpointmpathi.name; coutpointmpath0.

8、name; printf(t 路程为:%dn,gmst); printf(n是否返回主菜单? Y/N: ); char ss10; scanf(%s,ss); if(ss0=Y) system(cls); return ; void deletepoint()/删除某一个景点 while(1) if(n=0) printf(没有景点!); return ; menu(); int key; printf(请输入要删去的景点的标号:); scanf(%d,&key); for(int i=1;i=n;i+) if(Mapkeyi!=0) Mapkeyi=Mapikey=0; m-; for(in

9、t i=key+1;i=n;i+) pointi-1=pointi; for(int j=1;j=n;j+) if(Mapij!=0&j!=key) Mapi-1j=Mapji-1=Mapij; Mapij=Mapji=0; gpointi.name=i-1; n-; printf(删除成功! 是否继续删除? Y/N: ); char ss10; scanf(%s,ss); if(ss0=N) system(cls); return ; 五、调试分析调试过程主要是运行编制好的程序,然后遇到错误后根据系统的提示,找到相关的问题所在。本系统调试过程中遇到问题、原因和解决方法如下面介绍.运行完程序一

10、次有错误提醒 原因是上次运行程序后没有关闭操作界面当点击编译时会有一个错误提示,解决方法:将上一次运行时的操作界面关闭。 其原因是指针指向的位置出现错误导致程序传参错乱,无法运行,解决办法:使程序进入调试状态在传参,出现错误的位置一句句查找传递的参数是否是你所希望的,如若不是就加以修正时间复杂度O()优缺点分析Floyd算法适用于APSP(All Pairs Shortest Paths),是一种动态规划算法,稠密图效果最佳,边权可正可负。此算法简单有效,由于三重循环结构紧凑,对于稠密图,效率要高于执行|V|次Dijkstra算法。优点:容易理解,可以算出任意两个节点之间的最短距离,代码编写简

11、单;缺点:时间复杂度比较高,不适合计算大量数据。六、运行结果七、心得体会 做一个系统之前还应该做好全面的安排,对一个系统的整个流程及功能实现有一个很好的统筹,在遇到困难时,应查资料或问其它懂的同学,参考一下意见,再结合自己的想法,最后实现自己想实现的功能。在编写代码的时候要注意摒弃一些不好的习惯,细心地写好每一行代码,采取缩格排版,这样可以避免出现很多不应该出现的错误,也为后面的调试省去了很多环节,不必再为小细节而浪费时间,节省了很多时间。回顾起此课程设计,至今我仍感慨颇多,从理论到实践,但是可以学到很多很多的东西,同时不仅可以巩固了以前所学过的知识,而且学到了很多在书本上所没有学到过的知识。通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能提高自己的实际动手能力和独立思考的能力。参考资料 算法设计与分析(第2版) 王晓东编著 清华大学出版社数据结构(C语言版) 严蔚敏 吴伟民编著 清华大学出版社C语言程序设计 谭浩强著 清华大学出版社

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1