定义:
并查集是一种树型的数据结构,用于处理一些不相交集合的合并及查询问题(即所谓的并、查)。
初始化
for(int i=1;i<=n;i++)
fa[i]=i;
查询
int find(int i)
{
if(fa[i]==i)return i;
return find(fa[i]);
}
合并
void join(int i,intj)
{
int i_fa=find(i);
int j_fa=find(j);
fa[i_fa]=j_fa;
}
#include<bits/stdc++.h>
using namespace std;
int n,m,fa[10010],z,x,y;
int find(int i){
if(fa[i]==i)return i;
fa[i]=find(fa[i]);
return fa[i];
}
int main()
{
scanf("%d %d",&n,&m);
for(int i=1;i<=n;i++)
fa[i]=i;
while(m--){
scanf("%d %d %d",&z,&x,&y);
if(z==1)
fa[find(x)]=find(y);
else
if(find(x)==find(y))
printf("Y\n");
else
printf("N\n");
}
return 0;
}
#include<bitsdc++.h>
using namespace std;
int n,m,fa[10005],cnt=0,ans=0;
struct gl{
int x,y,t;
}a[100008];
bool cmp(gl a,gl b){
return a.t<b.t;
}
int find(int x){
if(fa[x]!=x)fa[x]=find(fa[x]);
return fa[x];
}
int main()
{
scanf("%d %d",&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].t);
sort(a+1,a+1+m,cmp);
for(int i=1;i<=m;i++){
int f1=find(a[i].x);int f2=find(a[i].y);
if(f1==f2)continue;
fa[f1]=f2;
cnt++;
ans=max(ans,a[i].t);
}
if(cnt!=n-1)printf("-1");
else printf("%d",ans);
}