Cod sursa(job #2119149)
Utilizator | Data | 31 ianuarie 2018 18:30:47 | |
---|---|---|---|
Problema | Paduri de multimi disjuncte | Scor | 70 |
Compilator | cpp | Status | done |
Runda | Arhiva educationala | Marime | 0.56 kb |
#include <bits/stdc++.h>
using namespace std;
int t[100010];
int arb(int x){
if (t[x]==x) return x;
else return arb(t[x]);
}
int main()
{
freopen("disjoint.in","r",stdin);
freopen("disjoint.out","w",stdout);
int n,m,i,p,x,y;
scanf("%d%d",&n,&m);
for (i=1;i<=n;i++) t[i]=i;
for (i=1;i<=m;i++){
scanf("%d%d%d",&p,&x,&y);
if (p==1){
t[arb(x)]=y;
}
else{
if (arb(x)==arb(y)) printf("DA\n");
else printf("NU\n");
}
}
return 0;
}