sample input
1 0
2 3
1 2 37
2 1 17
1 2 68
3 7
1 2 19
2 3 11
3 1 7
1 3 5
2 3 89
3 1 91
1 2 32
5 7
1 2 5
2 3 7
2 4 8
4 5 11
3 5 10
1 5 6
4 2 12
0
sample output
0
17
16
26
题意
n个点,m条边,找到使n个点联通的最短路径长度
最小生成树模板题
代码
/**
克鲁斯卡尔
*/
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 3000
int n,m,sum,ans;
int f[N];
struct node
{
int a,b,c;
}e[N];
bool cmp(node x,node y)
{
return x.c<y.c;
}
int getf(int x)
{
if(f[x]==x) return x;
return f[x]=getf(f[x]);
}
void merge(int x)
{
int t1=getf(e[x].a);
int t2=getf(e[x].b);
if(t1!=t2){
f[t2]=t1;
sum+=e[x].c;
ans++;
}
}
int main()
{
while(~scanf("%d",&n)&&n){
scanf("%d",&m);
if(!m){
printf("0\n");
continue;
}
for(int i=1;i<=n;i++)
f[i]=i;
for(int i=1;i<=m;i++)
scanf("%d%d%d",&e[i].a,&e[i].b,&e[i].c);
sort(e+1,e+1+m,cmp); //对边进行排序
sum=0,ans=0;
for(int i=1;i<=m;i++){
merge(i); //合并边
if(ans==n-1) break; //建树成功
}
printf("%d\n",sum);
}
return 0;
}