《面向对象程序设计》课程设计报告--畅通工程.docx
《《面向对象程序设计》课程设计报告--畅通工程.docx》由会员分享,可在线阅读,更多相关《《面向对象程序设计》课程设计报告--畅通工程.docx(7页珍藏版)》请在优知文库上搜索。
1、数据结构课程设计报告题目:畅通工程专业:数字媒体技术班级:数字151姓名:学号:指导教师:目录1问题描述22问题分析33程序设计44程序代码55参考文献66程序设计与运行结果L设计内容及要求1.问题描述某省调查乡村交通状况祠到的统计表中列出了任意两村庄间的距离。省政 府”畅通工程”的目标是使全省负何两个村庄间都可以实现公路交通但不一定 有直接的公路相 连,只要能间接通过公路可达即可,请设计一个方案,在哪些 村庄之间修路才能使铺设的公路总长度最小,并计算最小的公路总长度。2、问题分析假设以每个村庄为顶点,村庄之间的道路为边,可以用一个图来表示各个村 庄之间的 交通道路情况。因为任何两个村庄之间都
2、可以修路,所以有n个村庄 就可以修n(nD /2条道路。显然这是一个完全无向图,根据图的连通性 可知,N个村庄之间只要修nl条 道路就能保证各个村庄之间是相通的,那 么如何在这n(n 1) / 2条道路中选择n-l条呢?这个问题就转化为求连通图的最小生成树问题。求最小生成树有两种方法:Prim算法和KrUSkaI 算法。Prim算法适合求稠密图;KUSkaI算法适合求稀疏图。本问题涉及的边数 较多,因此选用Prinl算法比较台适。3、程序设计选用邻接表作为图的存储结构,每个村庄作为图中的顶点,为了运算方便, 给每个村庄一个编号,边表示两个村庄之间的道路,道路的长度作为边上的权值。深入浅出数据结
3、构与算法涉及的边数较多,因此选用Prim算法比较合适。 /*图的邻接表存储结构*/ define MAXN IOO struct ArcNode/*定义邻接表的边结构* /int adjvex, info;*adjvex是顶点编号,info表示边的长度*/struct ArcNode *nextarc; /* 指向下一条边。/);struct VNode/*定义邻接表的顶点向量*/int data;ArcNode * f irstarc;/* 指向第一条边大/AdjListMAXN;输入设计:第一行给出村庄数目N(GOO),当N为。时,输入结束。随后的N(N- 1)/2行对应村庄间的距离,每行
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 面向对象程序设计 面向 对象 程序设计 课程设计 报告 畅通 工程