标签:int ++ clu 生成 cost kruskal算法 turn 最小生成树 find
#include <bits/stdc++.h>
using namespace std;
int f[200010],r[200010];
int num[200010],to[200010],cost[200010];
int n,m;
bool cmp(int a,int b)
{
return cost[a]<cost[b];
}
int find(int k)
{
return f[k]==k?k:f[k]=find(f[k]);
}
int main()
{
cin>>n>>m;
int ans=0,sum=0;
for(int i=0;i<m;i++)
cin>>num[i]>>to[i]>>cost[i];
for(int i=0;i<n;i++)
f[i]=i;
for(int i=0;i<m;i++)
r[i]=i;
sort(r,r+m,cmp);
for(int i=0;i<m;i++)
if(find(num[r[i]])!=find(to[r[i]]))
{
ans+=cost[r[i]];
f[find(num[r[i]])]=find(to[r[i]]);
}
cout<<ans;
}
标签:int ++ clu 生成 cost kruskal算法 turn 最小生成树 find
原文地址:https://www.cnblogs.com/baccano-acmer/p/9914566.html