繁忙都市
题目链接:繁忙都市
题目描述
解题思路
最小生成树模板, k r u s k a l kruskal kruskal ,并查集优化。
code
#include<iostream>
#include<cstdio>
#include<algorithm>
using namespace std;
int n,m,ans;
int fa[100010];
struct abc{
int x,y,z;
}a[100010];
bool cmp(abc a,abc b)
{
return a.z<b.z;
}
int fd(int now)
{
if(fa[now]==now)
return now;
return fa[now]=fd(fa[now]);
}
int main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
fa[i]=i;
for(int i=1;i<=m;i++)
scanf("%d%d%d",&a[i].x,&a[i].y,&a[i].z);
sort(a+1,a+m+1,cmp);
for(int i=1;i<=m;i++)
{
int fx=fd(a[i].x);
int fy=fd(a[i].y);
if(fx!=fy)
fa[fx]=fy,ans=max(ans,a[i].z);
}
cout<<n-1<<" "<<ans<<endl;
}