- 1、本文档共12页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
一、课程设计题目: 校园最短路径问题
二、课程设计目的:
了解并掌握数据结构与算法的设计方法,具备初步的独立分析和设计能力;
初步掌握软件开发过程的问题分析、系统设计、程序编码、测试等基本方法
和技能;
提高综合运用所学的理论知识和方法独立分析和解决问题的能力;
训练用系统的观点和软件开发一般规范进行软件开发,培养软件工作者所具备的科学工作方法和作风。
三、课程设计要求:
设计的题目要求达到一定的工作量(300行以上代码),并具有一定的深度和
难度。
编写出课程设计报告书,内容不少于10页(代码不算)。
四、需求分析 :
1、问题描述
图的最短路径问题是指从指定的某一点v开始,求得从该地点到图中其它各地点的最短路径,并且给出求得的最短路径的长度及途径的地点。除了完成最短路径的求解外,还能对该图进行修改,如顶点以及边的增删、边上权值的修改等。
校园最短路径问题中的数据元素有:
a) 顶点数
b) 边数
c) 边的长度
2、功能需求
要求完成以下功能:
输出顶点信息:将校园内各位置输出。
输出边的信息:将校园内每两个位置(若两个位置之间有直接路径)的距离输出。
修改:修改两个位置(若两个位置之间有直接路径)的距离,并重新输出每两个位置(若两个位置之间有直接路径)的距离。
求最短路径:输出给定两点之间的最短路径的长度及途径的地点或输出任意一点与其它各点的最短路径。
删除:删除任意一条边。
插入:插入任意一条边。
3、实现要点
a) 对图的创建采用邻接矩阵的存储结构,而且对图的操作设计成了模板类。为了便于处理,对于图中的每一个顶点和每一条边都设置了初值。
b) 为了便于访问,用户可以先输出所有的地点和距离。
c) 用户可以随意修改两点之间好的距离。
d) 用户可以增加及删除边。
e) 当用户操作错误时,系统会出现出错提示。
五、概要设计:
抽象数据类型图的定义如下:
ADT Graph{
数据对象V:V是具有相同特性数据元素的集合,称为顶点集。
数据关系R:
R={VR}
VR={(v,w)| v , w∈V, (v , w)表示v和w之间存在路径}
基本操作P:
CreatGraph(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, v)
初始条件: 图G存在,v和G中顶点具有相同特征。
操作结果: 删除G中顶点v及其相关的边。
InsertArc(G, v, w)
初始条件: 图G存在,v和w是G中两个顶点。
操作结果: 在G中增添弧v,w,若G是无向的,则还增添对称弧w,v。
DeleteArc(G, v, w)
初始条件: 图G存在,v和w是G中两个顶点。
操作结果: 在G中删除弧v,w,若G是无向的,则还删除对称弧w,v。
} ADT Graph
主程序
void main()
{
初始化;
while(“命令”!=“退出”)
{
Switch语句
接受命令(输入选择项序号);
处理命令;
}
}
本程序运用函数的调用,只有两个模块,它们的调用关系为:
主程序模块
带权无向图模块
六、详细设计
(详细见下面的源代码)
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)
您可能关注的文档
最近下载
- 第六章煤层气钻井完井工艺技术.ppt VIP
- WI-PM-004ALL100烧录器操作规范.doc VIP
- 2025年国企审计部内部招聘试题.pdf VIP
- 文稿传输otn原理及设备介绍.pptx VIP
- BS EN 50600-2-2-2019 信息技术.数据中心设施和基础设施.第2-2部分:供电和配电.pdf VIP
- 中医护理方案2017解读.pptx VIP
- 标准图集-08CJ17快速软帘卷门 透明分节门 滑升门 卷帘门.pdf VIP
- 驭胜s350及电路图n351第三阶段2013-11-13分动器.pdf VIP
- 2025年安全生产考试题库(林业行业安全规范)试题集.docx VIP
- 检验科质量与安全管理制度培训学习资料.pptx VIP
文档评论(0)