Pagini recente » Cod sursa (job #165656) | Cod sursa (job #1275366) | Cod sursa (job #87986) | Atasamentele paginii Profil Motoc00 | Cod sursa (job #3348014)
#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;
x = Find(x);
y = Find(y);
if (cer == 1)
Union(x,y);
else{
if (x == y)
fout << "DA";
else
fout << "NU";
fout << '\n';
}
}
fin.close();
fout.close();
return 0;
}