#include<iostream>
#include<algorithm>
using namespace std;
int par[10005],ran[10005];
int u[10005],v[10005],w[10005],r[10005];
int cmp(const int i,const int j)
{return w[i]<w[j];}
void inital(int n)
{
for(int i=1;i<=n;i++)
{
par[i]=i;
ran[i]=0;
}
}
int find(int x)
{
if(x==par[x])return x;
else return par[x]=find(par[x]);
}
void unite(int x,int y)
{
int a=find(x);
int b=find(y);
if(a==b)return ;
if(ran[a]<ran[b])par[a]=b;
else
{
par[b]=a;
if(ran[a]==ran[b])
ran[a]++;
}
}
int kruskal(int n,int m)
{
int ans=0;
inital(n);
for(int i=1;i<=m;i++)
r[i]=i;
sort(r,r+m,cmp);
for(int i=1;i<=m;i++)
{
int e=r[i];
int x=find(u[e]);
int y=find(v[e]);
if(x!=y)
{
ans+=w[e];
unite(v[e],u[e]);
}
}
return ans;
}
int main()
{
int i,j,k,m,n;
while(cin>>n&&n)
{
m=(n-1)*n/2;
for(i=1;i<=m;i++)
cin>>u[i]>>v[i]>>w[i];
cout<<kruskal(n,m)<<endl;
}
}
hdoj 还是畅通工程 并查集实现Kruskal算法
最新推荐文章于 2019-11-01 17:59:41 发布