Cod sursa(job #2618201)

Utilizator RobertLearnsCDragomir Robert. RobertLearnsC Data 23 mai 2020 20:46:52
Problema Paduri de multimi disjuncte Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.79 kb
#include <bits/stdc++.h>
using namespace std;

vector <int> ind;
int n, m;

int root(int x) {
    if(ind[x] == x) {
        return x;
    }
    return (ind[x] = root(ind[x]));
}

void fabricaDeUnire(int x, int y) {
    ind[root(y)] = root(x);
}

int main() {
    freopen("disjoint.in", "r", stdin);
    freopen("disjoint.out", "w", stdout);

    scanf("%d%d", &n, &m);

    for(int i = 0; i < n; ++i) {
        ind.push_back(i);
    }

    for(int i = 0; i < m; ++i) {
        int op, x, y;
        scanf("%d%d%d", &op, &x, &y);

        if(op == 1) {
            fabricaDeUnire(x, y);
        } else {
            if(root(x) == root(y)) {
                printf("DA\n");
            } else {
                printf("NU\n");
            }
        }
    }
    return 0;
}