不知道为啥,用快读写就炸了,换成scanf就过了
原WA代码:
#include<cstdio>
using namespace std;
int a[10020];
int find(int x)
{
if(x!=a[x])a[x]=find(a[x]);
return a[x];
}
void _union(int x,int y)
{
int x1=find(x),y1=find(y);
a[y1]=a[x1];
}
int read()
{
int num=0;
char c=getchar();
while(c<'0'&&c>'9')c=getchar();
while('0'<=c&&c<='9'){
num=num*10+c-'0';c=getchar();}
return num;
}
int n,m;
int x,y,z;
int main()
{
n=read();
m=read();
for(int i=1;i<=n;i++)a[i]=i;
for(int i=1;i<=m;i++)
{
z=read();
x=read();
y=read();
//printf("Z:%d ",z);
if(z==1)_union(x,y);
if(z==2)
{
//if(a[x]==a[y])printf("Y\n");
if(find(x)==find(y))printf("Y\n");
else printf("N\n");
}
}
return 0;
}
把快读换成 scanf("%d %d %d",&z,&x,&y);就AC了
emmm还有个问题,为啥必须得写 if(find(x)==find(y)),不能写if(a[x]==a[y]),(写后者没过样例)
求大佬指导QwQ