#include<algorithm>
#include<iostream>
#include<cstring>
using namespace std;
const int N=2e5+10;
int f[N];
struct Edge
{
int a,b,w;
bool operator<(const Edge &W) const
{
return w<W.w;
}
}edge[N];
int find(int x)
{
if(f[x]!=x) f[x]=find(f[x]);
return f[x];
}
int main()
{
int n,m;
cin>>n>>m;
for(int i=0;i<m;i++)
{
int a,b,c;
cin>>a>>b>>c;
edge[i]={a,b,c};
}
for(int i=1;i<=n;i++)
{
f[i]=i;
}
sort(edge,edge+m);//把边从小到大排序
int res=0,cnt=0;
for(int i=0;i<m;i++)//加边法
{
int a=edge[i].a,b=edge[i].b,w=edge[i].w;
a=find(a);
b=find(b);
if(a!=b)//未在同一集合
{
f[a]=b;
res+=w;
cnt++;记录点的个数
}
}
if(cnt<n-1) cout<<"impossible"<<endl;
else cout<<res;
return 0;
}
AcWing 859. Kruskal算法求最小生成树
最新推荐文章于 2022-07-04 21:34:00 发布