HDOJ1863(畅通工程)

本文介绍了一个使用克鲁斯卡尔算法解决最小生成树问题的C语言实现。该算法通过逐步添加边来构造最小生成树,确保加入的每条边都不会形成环路。文章提供了完整的源代码,并解释了关键步骤。

题目链接

最小生成树的题。我用的克鲁斯卡尔算法。

View Code
 1 #include <stdio.h>
 2 #define N 100
 3 #define M 5000
 4 struct node
 5 {
 6     int a,b,d;
 7 }edge[M];
 8 int n,m;
 9 int p[N];
10 void make_set()
11 {
12     int i;
13     for(i=1;i<=n;i++)   p[i]=i;
14 }
15 int find_set(int i)
16 {
17     return i==p[i]?p[i]:(p[i]=find_set(p[i]));
18 }
19 void union_set(int i,int j)
20 {
21     p[j]=i;
22 }
23 int cmp(const void *a,const void *b)
24 {
25     return ((struct node*)a)->d-((struct node*)b)->d;
26 }
27 int main()
28 {
29     int i,ans,cnt;
30     while(scanf("%d%d",&m,&n)&&m)
31     {
32         for(i=0;i<m;i++)    scanf("%d%d%d",&edge[i].a,&edge[i].b,&edge[i].d);
33         ans=cnt=0;
34         make_set();
35         qsort(edge,m,sizeof(edge[0]),cmp);
36         for(i=0;cnt<n-1&&i<m;i++)
37         {
38             if(find_set(edge[i].a)==find_set(edge[i].b))    continue;
39             ans+=edge[i].d;
40             union_set(edge[i].a,edge[i].b);
41             cnt++;
42         }
43         if(cnt==n-1)    printf("%d\n",ans);
44         else    printf("?\n");
45     }
46     return 0;
47 }

 

转载于:https://www.cnblogs.com/algorithms/archive/2012/04/20/2459841.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值