Cod sursa(job #1053259)

Utilizator Al3ks1002Alex Cociorva Al3ks1002 Data 12 decembrie 2013 16:34:49
Problema Paduri de multimi disjuncte Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.56 kb
#include<cstdio>
using namespace std;
int N,M,Father[100005],C,X,Y,i;
int Find(int X)
{
    if(Father[X]!=X) Father[X]=Find(Father[X]);
    return 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;
}