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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

数据结构 课程设计 校园最短路径问题.docx

1、数据结构 课程设计 校园最短路径问题一、课程设计题目: 校园最短路径问题二、课程设计目的:1.了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;2.初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法和技能;3.提高综合运用所学的理论知识和方法独立分析和解决问题的能力;4.训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所具备的科学工作方法和作风。三、课程设计要求:1.设计的题目要求达到一定的工作量(300行以上代码),并具有一定的深度和难度。2.编写出课程设计报告书,内容不少于10页(代码不算)。四、需求分析 :1、问题描述图的最短路径问题是指从指

2、定的某一点v开始,求得从该地点到图中其它各地点的最短路径,并且给出求得的最短路径的长度及途径的地点。除了完成最短路径的求解外,还能对该图进行修改,如顶点以及边的增删、边上权值的修改等。校园最短路径问题中的数据元素有:a) 顶点数b) 边数c) 边的长度2、功能需求 要求完成以下功能:a)输出顶点信息:将校园内各位置输出。b)输出边的信息:将校园内每两个位置(若两个位置之间有直接路径)的距离输出。c)修改:修改两个位置(若两个位置之间有直接路径)的距离,并重新输出每两个位置(若两个位置之间有直接路径)的距离。d)求最短路径:输出给定两点之间的最短路径的长度及途径的地点或输出任意一点与其它各点的最

3、短路径。e)删除:删除任意一条边。f)插入:插入任意一条边。3、实现要点 a) 对图的创建采用邻接矩阵的存储结构,而且对图的操作设计成了模板类。为了便于处理,对于图中的每一个顶点和每一条边都设置了初值。 b) 为了便于访问,用户可以先输出所有的地点和距离。 c) 用户可以随意修改两点之间好的距离。 d) 用户可以增加及删除边。 e) 当用户操作错误时,系统会出现出错提示。五、概要设计:1.抽象数据类型图的定义如下:ADT Graph数据对象V:V是具有相同特性数据元素的集合,称为顶点集。数据关系R:R=VRVR=(v,w)| v , wV, (v , w)表示v和w之间存在路径基本操作P:Cr

4、eatGraph(&G, V, VR)初始条件: V是图的顶点集,VR是图中边的集合。操作结果: 按定义(V, VR) 构造图G。DestroyGraph(&G)初始条件: 图G已存在。操作结果: 销毁图。LocateVex(G, u) 初始条件: 图G存在,u和G中顶点具有相同特征。操作结果: 若G中存在顶点u,则返回该顶点在图中“位置” ;否则返回其它信息。GetVex(G, v) 初始条件: 图G存在,v是G中某个顶点。操作结果: 返回v的信息。InsertVex(&G, v) 初始条件: 图G存在,v和G中顶点具有相同特征。操作结果: 在图G中增添新顶点v。DeleteVex(&G,

5、v)初始条件: 图G存在,v和G中顶点具有相同特征。操作结果: 删除G中顶点v及其相关的边。InsertArc(&G, v, w) 初始条件: 图G存在,v和w是G中两个顶点。操作结果: 在G中增添弧,若G是无向的,则还增添对称弧。DeleteArc(&G, v, w)初始条件: 图G存在,v和w是G中两个顶点。操作结果: 在G中删除弧,若G是无向的,则还删除对称弧。 ADT Graph2.主程序void main() 初始化; while(“命令”!=“退出”) Switch语句 接受命令(输入选择项序号); 处理命令; 3.本程序运用函数的调用,只有两个模块,它们的调用关系为:主程序模块带

6、权无向图模块六、详细设计(详细见下面的源代码)typedef struct /图中顶点表示点,存放点名称void Menu() /输出菜单void PutOutVex(MGraph *G) /输出每个顶点的信息void PutOutArc(MGraph *G) /输出每条边的信息void Dijkstra(MGraph * G) /迪杰斯特拉算法求最短路径void DeleteVex(MGraph *G) /删除某个顶点void DeleteArc(MGraph *G) /删除某条边void InsertArc(MGraph *G) /插入某条边void main() /主函数七、源程序代码#

7、include #include #include #include #include #include #define MAX 10000 #define MAXLEN 8 #define ADJTYPE int typedef struct /图中顶点表示点,存放点名称 char name30; int num; VEXTYPE; typedef struct VEXTYPE vexsMAXLEN; /顶点的信息 ADJTYPE arcsMAXLENMAXLEN; /邻接矩阵 int vexnum,arcnum ; /顶点数和边数 MGraph;MGraph b; MGraph InitG

8、raph() /*建立无向网的邻接矩阵结构*/ int i, j; MGraph G; G.vexnum =8; /存放顶点数G.arcnum =13; /存放边点数 for(i=0;iG.vexnum;i+) G.vexsi.num=i; strcpy(G.vexs0.name,第四教学楼); strcpy(G.vexs1.name,第三教学楼); strcpy(G.vexs2.name,图书馆); strcpy(G.vexs3.name,食堂); strcpy(G.vexs4.name,第一教学楼); strcpy(G.vexs5.name,第二教学楼); strcpy(G.vexs6.n

9、ame,综合实验楼); strcpy(G.vexs7.name,校医院); for(i=0;iG.vexnum;i+) for(j=0;jG.vexnum;j+) G.arcsij=MAX;G.arcs01=130;G.arcs02=80; G.arcs03=260; G.arcs13=75; G.arcs24=50; G.arcs34=120; G.arcs15=265; G.arcs35=85; G.arcs36=400; G.arcs46=350; G.arcs56=120; G.arcs47=200; G.arcs67=150; for(i=0;iG.vexnum;i+) for(j=

10、0;jG.vexnum;j+) G.arcsji=G.arcsij;return G;void Menu() /输出菜单 cout需要输出顶点的信息请按0n; cout需要边的信息输出请按1n; cout需要修改请按2n; cout需要求出最短路径请按3n; cout需要删除某个顶点请按4n; cout需要删除某条边请按5n; cout需要插入某条边请按6n; cout需要退出请按7n; void PutOutVex(MGraph *G) /输出每个顶点的信息int v; for(v=0;vvexnum;v+) coutvexsv.numvexsv.nameendl; void PutOutA

11、rc(MGraph *G) /输出每条边的信息for(int i=0;ivexnum;i+) for(int j=0;jvexnum;j+) if(G-arcsijMAX) cout从 vexsi.name到vexsj.namearcsijendl; void Change(MGraph *G) /修改 int v0,v1,length; coutv0; cinv1; coutlength; G-arcsv0v1=G-arcsv1v0=length;void Dijkstra(MGraph * G) /迪杰斯特拉算法求最短路径 int v,w,i,min,t=0,x,v0,v1; int fi

12、nal20, D20, p2020; coutv0; if(v0G-vexnum) coutv0; coutv1; if(v1G-vexnum) coutv1; for(v=0;vvexnum;v+) / 初始化final20,p2020,finalv=1即已经求得v0到v的最短路径, /pvw=1则是w从v0到v当前求得最短路径上的顶点,Dv带权长度 finalv=0; Dv=G-arcsv0v; for(w=0;wvexnum;w+) pvw=0; if(DvMAX) pvv0=1;pvv=1; Dv0=0;finalv0=1; for(i=1;ivexnum;i+) min=MAX; f

13、or(w=0;wvexnum;w+) if(!finalw) if(Dwmin)v=w;min=Dw; finalv=1; for(w=0;wvexnum;w+) if(!finalw&(min+G-arcsvwarcsvw; for(x=0;xvexnum;x+) pwx=pvx; pww=1; cout从vexsv0.name到vexsv1.name的最短路径长度为:Dv1endl; cout路径为:; for(int j=0;jvexnum;j+) if(pv1j=1) coutvexsj.nameendl; void DeleteVex(MGraph *G) /删除某个顶点 int r

14、ow,col; int v0; coutv0; for(int i=v0;ivexnum;i+) G-vexsi=G-vexsi+1; G-vexnum-; for(row=0;rowvexnum;row+) for(col=v0;colvexnum;col+) G-arcsrowcol=G-arcsrowcol+1; for(col=0;colvexnum;col+) for(row=v0;rowvexnum;row+) G-arcscolrow=G-arcscolrow+1; void DeleteArc(MGraph *G) /删除某条边 int v0,v1; coutv0v1; G-a

15、rcsv0v1=MAX; G-arcsv1v0=MAX;void InsertArc(MGraph *G) /插入某条边 int v0,v1,l=0; coutv0v1; coutl; G-arcsv0v1=l; G-arcsv1v0=l;void main() /主函数 int a; b=InitGraph(); Menu(); cina; while(a!=7) switch(a) case 0:PutOutVex(&b);Menu();break; case 1:PutOutArc(&b);Menu();break; case 2:Change(&b);Menu();break; cas

16、e 3:Dijkstra(&b);Menu();break; case 4:DeleteVex(&b);Menu();break; case 5:DeleteArc(&b);Menu();break; case 6:InsertArc(&b);Menu();break; case 7:exit(1);break; default:break; cina; 八、调试分析 1) 本程序在求最短路径的问题上采用迪杰斯特拉算法解决,虽然该算法与弗洛伊德算法相比时间复杂度低,但每求一条最短路径都必须重新搜索一遍,在频繁查询时会导致查询效率低,而弗洛伊德算法只要计算一次,即可求得每一对顶点之间的最短路径,

17、虽然时间复杂度为高,但以后每次查询只要查表即可,会极大地提高查询的效率,而且,弗洛伊德算法还支持带负权的图的最短路径的计算。由此可见,选用算法时必须综合各方面因素考虑。2) 由于功能函数较多,在编写程序时将函数逐个添加完成的,就是说,每增加一个函数,进行一次编译运行,此函数通过了再写下一个函数。或许这种方法比较麻烦,但当有错误时只要针对新加函数进行修改即可。同时,要充分利用软件所提供的调试功能,这也会大大减少编程人员的负担。九、调试结果a) 开始界面b) 输出顶点信息c) 输出边的信息d) 修改e) 求最短路径f) 删除某一顶点g) 删除某条边 h) 插入某条边i) 退出十、总结及体会 课程设

18、计是培养学生综合运用所学知识,发现,提出,分析和解决实际问题,锻炼实践能力的重要环节,是对学生实际工作能力的具体训练和考察过程。通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,将结论用于实践,从而提高自己的实际动手能力和独立思考的能力。在设计的过程中当然遇到了问题,可以说得是困难重重,毕竟这是不可避免的,同时在设计的过程中发现了自己的不足之处,对以前所学过的知识理解得不够深刻,掌握得不够牢固。当指导老师提到用动态数组和链接表来解决这一问题时,我却一头雾水,才发现自己的知识面太窄。由于编程水平有限,其中迪杰斯特拉算法的C+程序是参考网上的资料,还有顶点的插入设计中没有体现。我想在以后的学习中,要更注重实践这一环节。

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

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