kruskal算法,水题飘过。。。
附上代码:
#include<stdio.h>
#include<string.h>
#include<algorithm>
using namespace std;
#define N 1000
int n,m;
int a[N],b[N];
struct node
{
int x;
int y;
int dis;
}text[N];
int comp(const node a,const node b)
{
return a.dis<=b.dis;
}
int findl(int x)
{
if(x!=a[x])
a[x]=findl(a[x]);
return a[x];
}
int main()
{
int i,j,k,r;
int sum,tx,ty;
while(scanf("%d%d",&n,&m)&&n)
{
for(i=0;i<n;i++)
{
scanf("%d%d%d",&text[i].x,&text[i].y,&text[i].dis);
}
for(i=0;i<m;i++)
a[i]=i;
sort(text,text+n,comp);
sum=0;
k=0;
for(i=0;i<n;i++)
{
tx=findl(text[i].x);
ty=findl(text[i].y);
if(tx!=ty)
{
sum+=text[i].dis;
a[tx]=ty;
k++;
}
}
if(k==m-1)
printf("%d\n",sum);
else
printf("?\n");
}
return 0;
}