70分TLE求助
查看原帖
70分TLE求助
427590
SHENTONG_ZY楼主2021/9/27 13:16
#include<bits/stdc++.h>
using namespace std;
int a[100000],n,m,x,y,z;
int da(int x){
	if(a[x]==x) return x;
	else return da(a[x]);
}
bool check(int x,int y){
	if(da(x)==da(y)) return true;
	return false;
}
int hb(int x,int y){
	if(check(x,y)==false){
		a[da(x)]=da(y);
	}
}
int main(){
	cin>>n>>m;
	for(int i=1;i<=n;i++) a[i]=i;
	for(int i=1;i<=m;i++){
		scanf("%d%d%d",&z,&x,&y);
		if(z==1) hb(x,y);
		else{
			if(check(x,y)==true) printf("Y\n");
			else printf("N\n");
		}
	}
	
	return 0;
} 
2021/9/27 13:16
加载中...