Pagini recente » Cod sursa (job #1131216) | Cod sursa (job #1556459) | Cod sursa (job #1947404) | Cod sursa (job #2595872) | Cod sursa (job #1053257)
#include<cstdio>
using namespace std;
int N,M,Father[100005],C,X,Y,i;
int Find(int X)
{
if(Father[X]==X) return X;
Father[X]=Find(Father[X]);
}
void Unite(int X,int Y)
{
Father[Y]=X;
}
int main()
{
freopen("disjoint.in","r",stdin);
freopen("disjoint.out","w",stdout);
scanf("%d%d",&N,&M);
for(i=1;i<=N;i++) Father[i]=i;
for(;M;M--)
{
scanf("%d%d%d",&C,&X,&Y);
if(C==1) Unite(Find(X),Find(Y));
else {if(Find(X)==Find(Y)) printf("DA\n"); else printf("NU\n");}
}
return 0;
}