- 28
- 0
- 约2.52万字
- 约 23页
- 2018-12-21 发布于浙江
- 举报
实习报告
实验名称:数据结构基本算法演示程序 日期:2017年7月1 日
姓名:于博 学号班级:信1501-2 指导教师:陈娜
1.实验题目
Prim 算法 输入:无向图(顶点序列,边序列)
功能要求:输出最小生成树的各组成边及最小生成树的权值
Kruskal 算法 输入:无向图(顶点序列,边序列)
功能要求:输出最小生成树的各组成边及最小生成树的权值
Floyd 算法 输入:有向图(顶点序列,有向边序列)
功能要求:输出各顶点对间最短路径和路径长度
Dijkstra 算法
输入:有向图(顶点序列,有向边序列),起始顶点
功能要求:输出起始顶点到其它各顶点的最短路径和路径长度
2.需求分析
本演示程序用C++编写,完成四个算法的实现, Prim 算法,Kruskal 算法,Floyd 算法,Dijkstra 算法
① 输入的形式和输入值的范围: 整数,菜单项是1至5,其他输入根据图的实际情况。
② 输出的形式:输出最小生成树,树的各组成边,所有路径及源点到其他点的所有最短路径。
③ 程序所能达到的功能:四个算法Prim 算法,Kruskal 算法,Floyd 算法,Dijkstra 算法的实现。
④ 测试数据:
A. 输入3个点,3条边。
B. 输入1 3 50 1 2 20 2 3 10三组点及权值。
3.概要设计
1) 为了实现上述程序功能,需要定义树、线性表的抽象数据类型:
ADT Tree{
数据对象:D={ai|ai∈IntegerSet,i=0,1,2,…,n,n≥0}
数据关系:R={ai,ai+1|ai,ai+1 ∈D}
ADT LinkList{
数据对象:D={ai|ai∈IntegerSet,i=0,1,2,…,n,n≥0}
数据关系:R={ai,ai+1|ai,ai+1 ∈D}
基本操作:
Prim算法
ok(Tree t,int k)
初始条件:树结构已存在
操作结果:作为判断函数的条件
judge(Tree t)
初始条件:树结构已存在
操作结果:判断树是否包含所有图的结点
show_prim()
初始条件:树结构已存在,prim算法运行成功
操作结果:展示prim算法,输出最小生成树
Kruskal 算法
Find(int x)
初始条件:图已存在
操作结果:查寻父节点
Union(int x,int y)
初始条件:图已存在
操作结果:合并结点
bool Com(Node x,Node y)
初始条件:图已存在
操作结果:判断结点权值
show_kruskal()
初始条件:图已存在,kruskal算法运行成功
操作结果:展示kruskal算法,输出各组成边
Floyd 算法
F_Creategraph(F_MGraph *F_MGraph)
操作结果:创建图
Floyd(F_MGraph *F_MGraph, int **iArrPath)
初始条件:图已存在
操作结果:运行弗洛伊德算法
PrintResult(F_MGraph *F_MGraph, int **iArrPath)
初始条件:图已存在
操作结果:打印图的信息
show_floyd()
初始条件:图已存在,弗洛伊德算法运行成功
操作结果:展示弗洛伊德算法
Dijkstra 算法
createGraph(HeadNode *G, int nodeNum, int arcNum)
操作结果:创建图
printGraph(HeadNode *G, int nodeNum)
初始条件:图已存在
操作结果:打印图
getWeight(HeadNode *G, int begin, int end)
初始条件:图已存在
操作结果:得到出发点到终点权重
Dijkstra(HeadNode *G, int nodeNum, int begin)
初始条件:图已存在,出发点已知
操作结果:运行迪杰斯特拉算法
printPath(HeadNode *G, int end)
初始条件:图已存,迪杰斯特拉算法运行成功
操作结果:打印路径
show_Dijkstra()
初始条件:图已存,迪杰斯特拉算法运行成功
操作结果:展示迪杰斯特拉算法
menu()
操作结果:在屏幕上显示操作菜单
2) 本程序包含 17个函数:
菜单函数menu()
Prim算法ok()
判断树是否包含所有图的结点judge()
展示prim算法函数show_prim()
Kruskal算法
Find()
合并结点函数Union()
判断节点权值函数bool Com()
展示kruskal算法函数show_kruskal()
您可能关注的文档
最近下载
- 一把手 2025年度在带头强化政治忠诚、提高政治能力;在带头固本培元、增强党性;在带头敬畏人民、敬畏组织、敬畏法纪;在带头干事创业、担当作为;在带头坚决扛起管党治党责任五个带头方面存在的问题.docx VIP
- 四川成都农业科技中心招聘真题2024.docx VIP
- 四库全书基本概念系列文库:韵略汇通.pdf VIP
- 元气森林外星人电解质水校园圈层营销方案.pptx VIP
- 中国儿童社交技能评估量表(儿童).docx VIP
- 成都农业科技中心招聘考试真题2024.docx VIP
- 《新媒体翻译(校企)》课程教学大纲(本科).docx VIP
- 《新媒体翻译(校企)》课程教学大纲(本科).pdf VIP
- 2024年成都农业科技中心招聘考试真题.pdf VIP
- 简论在象牙门与兽角门的交叉路口追寻道德要义.doc VIP
原创力文档

文档评论(0)