欢迎来到课桌文档! | 帮助中心 课桌文档-建筑工程资料库
课桌文档
全部分类
  • 党建之窗>
  • 感悟体会>
  • 百家争鸣>
  • 教育整顿>
  • 文笔提升>
  • 热门分类>
  • 计划总结>
  • 致辞演讲>
  • 在线阅读>
  • ImageVerifierCode 换一换
    首页 课桌文档 > 资源分类 > DOCX文档下载  

    《面向对象程序设计》课程设计报告--畅通工程.docx

    • 资源ID:286558       资源大小:29.79KB        全文页数:7页
    • 资源格式: DOCX        下载积分:5金币
    快捷下载 游客一键下载
    会员登录下载
    三方登录下载: 微信开放平台登录 QQ登录  
    下载资源需要5金币
    邮箱/手机:
    温馨提示:
    用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)
    支付方式: 支付宝    微信支付   
    验证码:   换一换

    加入VIP免费专享
     
    账号:
    密码:
    验证码:   换一换
      忘记密码?
        
    友情提示
    2、PDF文件下载后,可能会被浏览器默认打开,此种情况可以点击浏览器菜单,保存网页到桌面,就可以正常下载了。
    3、本站不支持迅雷下载,请使用电脑自带的IE浏览器,或者360浏览器、谷歌浏览器下载即可。
    4、本站资源下载后的文档和图纸-无水印,预览文档经过压缩,下载后原文更清晰。
    5、试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。

    《面向对象程序设计》课程设计报告--畅通工程.docx

    数据结构课程设计报告题目:畅通工程专业:数字媒体技术班级:数字151姓名:学号:指导教师:目录1问题描述22问题分析33程序设计44程序代码55参考文献66程序设计与运行结果L设计内容及要求1.问题描述某省调查乡村交通状况祠到的统计表中列出了任意两村庄间的距离。省政 府”畅通工程”的目标是使全省负何两个村庄间都可以实现公路交通但不一定 有直接的公路相 连,只要能间接通过公路可达即可,请设计一个方案,在哪些 村庄之间修路才能使铺设的公路总长度最小,并计算最小的公路总长度。2、问题分析假设以每个村庄为顶点,村庄之间的道路为边,可以用一个图来表示各个村 庄之间的 交通道路情况。因为任何两个村庄之间都可以修路,所以有n个村庄 就可以修n(nD /2条道路。显然这是一个完全无向图,根据图的连通性 可知,N个村庄之间只要修nl条 道路就能保证各个村庄之间是相通的,那 么如何在这n(n 1) / 2条道路中选择n-l条呢?这个问题就转化为求连通图的最小生成树问题。求最小生成树有两种方法:Prim算法和KrUSkaI 算法。Prim算法适合求稠密图;KUSkaI算法适合求稀疏图。本问题涉及的边数 较多,因此选用Prinl算法比较台适。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行对应村庄间的距离,每行给出一对正整数(分别是两个村庄的编号) 以及两村庄间的距离,村庄从1到N编号。输出设计:输出应建设的每一条道路的村庄编号及距离,并输出应建设道路的 最短距离。基本操作:InitO:初始化界面设计。InputO:输人两个村庄的编号及之间的距离。join(VNode * a, int b, int c):输入数据建立邻接表。PrimO :运用Prim算法求最小生成树。main():主函数。4 .程序代码ftinclude<stdio. h> ftinclude<limits. h> ftinclude<string. h> ftinclude<windows. h> Sdefine MAXN 100 int n, m, visitMAXN+5, lowMAXN+5; int i, a, b, c, Iength=O;struct ArcNode (int adjvex, info;struct ArcNode *nextarc;;struct VNode(int data;ArcNode *firstarc; AdjListNfAXN; void Init()printf (*畅通工程*);(N<100)nn");Printf (”请输入村庄数目N:void join (VNode *a, int b, int c)ArcNode *p,*q;p=new ArcNode;p->adjvex= b; p->info=c;p->nextarc=NULL;q=a->firstarc;a->firstarc=p;p->nextarc=q;void Input ()(scanf (,%dz, &n);m=n*(n-l)2;Printf ("n请输入对应村庄间的距离:n);Printf ("格式:村庄A的编号村庄B的编号两村庄间的距离r);printf ("共%d 行n”, m);for(i=l;i<=m;i+)(scanf ("%d%d%d”, &a, &b, &c);join(&AdjLista, b, c);join(&AdjList b, a, c);)void Prim()(int i, j, pos, min, Iength=O;ArcNode *p;printf (z,使用Prim算法计算其最小生成树并输出边nn");system (zzpausez,);puts(,z);memset(visit, 0, sizeof(visit);visit1=-1;pos=l;for(i=2;i<=m;i+)(lowi =INTJfAX;visiti=l;)p=AdjListl. firstarc;whiIe(p!=NULL)(lowp->adjvex=p->info;p=p->nextarc;for(i=l;i<n;i+÷)(Iiiin=INTJlAX;for(j=l;i<=n;j+)(if(visitj!=-l&&lowj<min)min=lowj;pos=J;length+=min;Printf (连接村%d和村%d,公路长度为dnn”, visitpos, pos, lowpos);visitpos=-l;P=AdjListEpos. firstarc;whiIe(p!=NULL)(if(p->adjvex!=-l&&p->info<lowp->adjvex) lowp->adjvex=p->info, visitp->adjvex=pos;p=p->nextarc;)Printf ("最小的公路长度为:%dn”, length);int main ()Init();InputO ;Prim();5、参考文献1刘晓华著.数据结构与算法.北京:清华大学出版社,20156.程序测试与运行结果

    注意事项

    本文(《面向对象程序设计》课程设计报告--畅通工程.docx)为本站会员(夺命阿水)主动上传,课桌文档仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知课桌文档(点击联系客服),我们立即给予删除!

    温馨提示:如果因为网速或其他原因下载失败请重新下载,重复下载不扣分。




    备案号:宁ICP备20000045号-1

    经营许可证:宁B2-20210002

    宁公网安备 64010402000986号

    课桌文档
    收起
    展开