




已阅读5页,还剩7页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
软 件 学 院课程设计报告书课程名称 数据结构 设计题目 地铁建设问题 专业班级 学 号 姓 名 指导教师 2014 年 1月17日9目录1 设计时间12 设计目的13设计任务14 设计内容14.1总体设计14.2需求分析24.3详细设计24.4测试与分析44.4.1测试44.4.2分析64.5 附录65 总结与展望10参考文献11成绩评定111 设计时间 2014年1月15日2 设计目的 设计各辖区之间最短地铁,使修建费用最少3设计任务 某城市要在各个辖区之间修建地铁,由于地铁建设费用昂贵,因此需要合理安排地铁建设线路,使市民可以沿地铁到达各个辖区,并使总费用最小。4 设计内容 (1)输入各个辖区名称和各辖区间直接距离(地铁铺设费用与距离成正比)。(2)根据辖区距离信息,计算出应该在哪些辖区建立地铁线路。(3)输出应该建设的地铁线路及所需建设总里程。 4.1总体设计图4-1算法图4.2需求分析(1)本程序设计计算城市内各辖区间修建地铁的最短路程。(2)运行时,输入辖区的名称,各辖区之间用空格键隔开,以#输入结束。(3)输入各辖区间距离时,先输入两辖区名称,再输入距离。(4)最后计算最短距离来得出最少费用。4.3详细设计采用邻接矩阵存储构造无向图int creatgraph(Graph *g) int i=0,j,m,k,p; char a10,b10; printf(请输入所有的辖区,以#为输入结束标志n); scanf(%s,g-Vi); while(strcmp(#,g-Vi)!=0) i+; scanf(%s,g-Vi); g-vexnum=i; for(i=0;ivexnum;i+) for(j=0;jvexnum;j+) g-Rij=INFINITY; printf(请输入辖区和辖区之间的路程,以#为结束标志n); scanf(%s%s%d,a,b,&m); while(strcmp(#,a)!=0 | strcmp(#,b)!=0 | m!=0) k=locatevex(g,a); p=locatevex(g,b);if(k=-1) printf(没有%s这个辖区n,a); return 0; if(p=-1) printf(没有%s这个辖区n,b); return 0;g-Rkp=g-Rpk=m;scanf(%s%s%d,a,b,&m); return 1;普利姆算法生成最小树struct tree /构造最小生成树/ int weizhi; int lowcost; ;int minimun(struct tree *a,Graph g) int i,k,m=0; for(i=0;ig.vexnum;i+) if(m=0 & ai.lowcost!=0) m=1; k=i;if(m=1 & ai.lowcost!=0) if(ai.lowcostak.lowcost) k=i; return k;4.4测试与分析4.4.1测试图4-1正确测试结果图4-2错误测试结果4.4.2分析调试时,在输入数据时,再输完数据后要再次按下空格键,再输入结束符号才会结束本次输入进入下一个输入。且不能输入与本次输入无关的数据或者超出本次输入限制的数据,否则显示错误,将重新输入。4.5 附录#include #include #include #include #define INFINITY 10000#define M 20 typedef struct char VM10; int RMM; int vexnum; Graph; int locatevex(Graph *g,char a10) int i; for(i=0;ivexnum;i+) if(strcmp(a,g-Vi)=0) return i; if(i=g-vexnum) return -1; int creatgraph(Graph *g) int i=0,j,m,k,p; char a10,b10; printf(请输入所有的辖区,以#为输入结束标志n); scanf(%s,g-Vi); while(strcmp(#,g-Vi)!=0) i+; scanf(%s,g-Vi); g-vexnum=i; for(i=0;ivexnum;i+) for(j=0;jvexnum;j+) g-Rij=INFINITY; printf(请输入辖区和辖区之间的路程,以#为结束标志n); scanf(%s%s%d,a,b,&m); while(strcmp(#,a)!=0 | strcmp(#,b)!=0 | m!=0) k=locatevex(g,a); p=locatevex(g,b);if(k=-1) printf(没有%s这个辖区n,a); return 0; if(p=-1) printf(没有%s这个辖区n,b); return 0;g-Rkp=g-Rpk=m;scanf(%s%s%d,a,b,&m); return 1;struct tree /构造最小生成树/ int weizhi; int lowcost; ;int minimun(struct tree *a,Graph g) int i,k,m=0; for(i=0;ig.vexnum;i+) if(m=0 & ai.lowcost!=0) m=1; k=i;if(m=1 & ai.lowcost!=0) if(ai.lowcostak.lowcost) k=i; return k;void MiniSpanTree_PRIM(Graph g,char a10) struct tree closedgeM; int i,j,k,money=0; k=locatevex(&g,a); if(k=-1) printf(没有%s这个辖区,无法求解n,a); return 0; for(i=0;ig.vexnum;i+) if(i!=k) closedgei.lowcost=g.Rki; closedgei.weizhi=k; closedgek.lowcost=0; for(i=1;ig.vexnum;i+) k=minimun(closedge,g); money+=closedgek.lowcost; printf(%d:%s %s %dn,i,g.V closedgek.weizhi ,g.Vk,closedgek.lowcost); closedgek.lowcost=0; for(j=0;jg.vexnum;j+) if(g.Rkjclosedgej.lowcost) closedgej.weizhi=k; closedgej.lowcost=g.Rkj; printf(总费用为:%dn,money);void main() int i,k; Graph g; char a10; printf(请选择功能: 1(铁路建设) 0(退出)n); scanf(%d,&k); while(k) i=creatgraph(&g); if(i) printf(请输入从哪里开始:); scanf(%s,a); MiniSpanTree_PRIM(g,a); printf(请选择功能: 1(铁路建设) 0(退出)n); scanf(%d,&k); 5 总结与展望本程序,本次编译涉及数据结构最小生成树以及图的构造等编译。先要构造结构体,在定义时应要注意尽量将赋值空间增大,以防止调试时输入数据超出运算范围。再进行函数的编译调用,构造无向图用邻接矩阵进行存储,这些编译代码,书上都有介绍,但不可尽抄,书上的只是一个模板,根据程序设计任务将变量进行修改,构造图之后,运用最小生成树原理,用普利姆算法对整个程序变量进行编译,最后进入主函数,就直接调用函数进行运算输入的数据,输出运算结果。这次程序的编译让我对图的遍历理解的更加深入,最小生成树问题不仅可以运算本次程序对地铁建造最少费用问题,更可以运用于一系列的最短距离等问题,解决甚多复杂问题!极其具有实用性!参考文献
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年三年级竞赛试卷及答案
- 2025年趣味数字比赛题目及答案
- 2025年手术室消毒隔离制度试题手术室消毒隔离制度试题及答案
- 2025年上半年幼儿园教师资格证保教知识与能力真题及答案
- 2025年山东省潍坊市事业单位教师招聘考试《教育理论》真题库及答案
- CN222988813U 一种具有口沿防烫结构的打包餐盒 (广东悦盛日塑科技有限公司)
- CN120262942A 一种单相并网差分降压逆变器、系统及控制方法 (陕西科技大学)
- 巧克力理论试题及答案
- 极限计算题目及答案
- CN120096918B 一种新能源电池自动贴胶机及其使用方法 (上海鸿掣自动化科技有限公司)
- 海姆立克急救法完整版本课件
- 部编版六年级上册语文全册课件-002
- 简介肾移植课件
- 发展社会学课件
- 【完整版】锁骨骨折护理查房课件
- 浅谈黄河三角洲生物多样性特点及保护对策
- 道德与法治-五年级(上册)-《主动拒绝烟酒与毒品》教学课件
- 人教统编版五年级上册道德与法治全册教学课件
- 有机化学实验课件PPT
- 中国饮食文化完整教案73777
- 自然拼读法在小学英语教学中的应用的实践研究
评论
0/150
提交评论