**给出一个无向图,求出最小生成树,如果该图不连通,则输出orz**
#include<bits/stdc++.h>
using namespace std;
struct rec{
int x,y,z;
}edge[500010];
int fa[100010],n,m,ans;
bool cmp(rec a,rec b){
return a.z<b.z;
}
int get(int x){
if(x==fa[x]) return x;
return fa[x]=get(fa[x]);
}
int main(){
cin>>n>>m;
for(int i=1;i<=m;i++) scanf("%d%d%d",&edge[i].x,&edge[i].y,&edge[i].z);
sort(edge+1,edge+1+m,cmp);
for(int i=1;i<=n;i++) fa[i]=i;
for(int i=1;i<=m;i++){
int x=get(edge[i].x);
int y=get(edge[i].y);
if(x==y) continue;
fa[x]=y;
ans+=edge[i].z;
}
cout<<ans;
}
最小生成树
最新推荐文章于 2023-01-09 21:31:04 发布