实验五.Kruskal算法的设计.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 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);

文档评论(0)

qwd513620855 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档