Pagini recente » Cod sursa (job #1379251) | Cod sursa (job #841681) | Cod sursa (job #3157670) | Cod sursa (job #1718480) | Cod sursa (job #3348011)
#include <bits/stdc++.h>
using namespace std;
#define MAXN 100000
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
int nxt[MAXN + 1];
inline void Union(int x,int y){
nxt[y] = x;
}
int Find(int x){
int sef,aux;
sef = x;
while (nxt[sef])
sef = nxt[sef];
while (nxt[x]){
aux = nxt[x];
nxt[x] = sef;
x = aux;
}
return sef;
}
int main(){
int n,m,cer,x,y,i;
fin >> n >> m;
for (i = 1; i <= m; i ++){
fin >> cer >> x >> y;
if (cer == 1)
Union(x,y);
else{
x = Find(x);
y = Find(y);
if (x == y)
fout << "DA";
else
fout << "NU";
fout << '\n';
}
}
fin.close();
fout.close();
return 0;
}