- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实验五.Kruskal算法的设计
实验五 Kruskal算法的设计(4学时)
[实验目的]
根据算法设计需要, 掌握连通网的灵活表示方法;
掌握最小生成树的Kruskal算法;
基本掌握贪心算法的一般设计方法;
进一步掌握集合的表示与操作算法的应用.
[预习要求]
认真阅读算法设计教材和数据结构教材内容, 熟习连通网的不同表示方法和最小生成树算法;
设计Kruskal算法实验程序.
实验目的:?1. 根据算法设计需要, 掌握连通网的灵活表示方法;2. 掌握最小生成树的Kruskal算法;3. 基本掌握贪心算法的一般设计方法;4. 进一步掌握集合的表示与操作算法的应用.实验内容:?? 编写 Kruskal 算法程序求最小生成树.代码:??void CreatGraph(MGraph *G)// 构件图{int i, j,n, m;?fscanf(fp1,%d,%d,G-arcnum,G-vexnum);// 输入边数和顶点数?for(i=1;i=G-vexnum;i++)// 初始化图? for(j=1;j=G-vexnum;j++)? G-arc[i][j].tag=0;// 初始化adj值?for(i=1;i=G-arcnum;i++)// 输入边和权值??{? fscanf(fp1,%d-%d,n,m);? G-arc[n][m].tag=1;?? fscanf(fp1,%d,G-arc[n][m].weight);?}}?void Swapn(edge *edges,int i,int j)// 交换权值 以及边的头和尾?{ int temp; ?? temp=edges[i].begin; ?? edges[i].begin=edges[j].begin;? edges[j].begin=temp;? temp=edges[i].end; ?? edges[i].end=edges[j].end;? edges[j].end=temp;? temp = edges[i].weight; ?? edges[i].weight=edges[j].weight;? edges[j].weight=temp;}??void sort(edge edges[],MGraph *G)// 对权值进行排序?{int i,j;?for(i=1;iG-arcnum;i++)? for(j=i+1;j=G-arcnum;j++)? if(edges[i].weightedges[j].weight)? Swapn(edges,i,j);?fprintf(fp2, 按权值从小到大排序后的各边及其权值:\n);?fprintf(fp2, 边 权值\n);?for(i=1;i=G-arcnum;i++)? fprintf(fp2,(%d,%d) %d\n,edges[i].begin,edges[i].end,edges[i].weight);}?int Find(int *parent,int f)?{while(parent[f]0) // 去掉回路? f=parent[f]; ??return f;}?void MiniSpanTree(MGraph *G)// 生成最小生成树?{int i,j,n,m;?int k=1;?int parent[M]; //parent 数组是用来去掉回路的?edge edges[M];?for(i=1;i=G-vexnum;i++)? for(j=1;j=G-vexnum;j++)? if(G-arc[i][j].tag == 1)? {edges[k].begin=i;? edges[k].end=j;? edges[k].weight=G-arc[i][j].weight;? k++;}?sort(edges,G);?for(i=1;i=G-arcnum;i++)? parent[i]=0; // 初始化parent值,便于后面的回路判断?fprintf(fp2, 最小生成树为:\n);?fprintf(fp2, 边 权值\n);?for(i=1;i=G-arcnum;i++) ??{n=Find(parent,edges[i].begin); // 注意阻止回路的发生? m=Find(parent,edges[i].end);? if(n!=m) // 若m=n则说明该边将会产生回路,应去掉? {parent[n]=m;? fprintf(fp2,(%d,%d) %d\n, edges[i].begin,edges[i].end,edges[i].weight);
您可能关注的文档
最近下载
- 八年级上名著《红岩》第10章(讲练测).docx VIP
- 表面处理技术在高端装备制造中的应用与挑战报告2025.docx
- 汪曾祺《钓鱼大夫》阅读答案试题解析理解 .pdf VIP
- 家庭反暴强制报告制度及服务流程.docx VIP
- 聚醚多元醇企业标准.pdf VIP
- 八年级上名著《红岩》第11章(讲练测).docx VIP
- T_CIATCM 093—2020_基层医疗卫生机构中医诊疗区(中医馆)团体标准远程会诊系统建设指南中国中医药信息学会.pdf VIP
- 八年级上名著《红岩》第12章(讲练测).docx VIP
- 2025国投生物制造创新研究院有限公司招聘(31人)考试备考试题及答案解析.docx VIP
- 边坡位移监测记录表.xlsx VIP
文档评论(0)