Pagini recente » Cod sursa (job #830476) | Cod sursa (job #2166067) | Cod sursa (job #2945577) | Cod sursa (job #3248100) | Cod sursa (job #2512284)
#include <cstdio>
#include <algorithm>
using namespace std;
const int NMAX = 100505;
int N, ops;
int parent[NMAX], size[NMAX];
int find(int x) {
int root = x;
while (parent[root] != root) {
root = parent[root];
}
while (parent[x] != x) {
int currNode = x;
x = parent[x];
parent[currNode] = root;
}
return root;
}
void merge(int x, int y) {
int rootX = find(x), rootY = find(y);
if (rootX == rootY) {
return;
} else {
if (size[rootX] < size[rootY]) {
swap(x, y);
}
parent[y] = x;
size[x] += size[y];
}
}
bool inSameSet(int x, int y) {
return find(x) == find(y);
}
int main() {
freopen("disjoint.in", "r", stdin);
freopen("disjoint.out", "w", stdout);
scanf("%d%d", &N, &ops);
for (int i = 1; i <= N; i++) {
parent[i] = i;
size[i] = 1;
}
int opType, x, y;
for (int op = 0; op < ops; op++) {
scanf("%d%d%d", &opType, &x, &y);
switch (opType) {
case 1:
merge(x, y);
break;
case 2:
printf("%s\n", inSameSet(x, y) ? "DA" : "NU");
break;
}
}
return 0;
}