Cod sursa(job #1644383)

Utilizator Vali_DeaconuVali Deaconu Vali_Deaconu Data 9 martie 2016 22:51:43
Problema Paduri de multimi disjuncte Scor 70
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
# include <cstdio>
# include <vector>

using namespace std;

FILE *fin = fopen("disjoint.in", "rt");
FILE *fout = fopen("disjoint.out", "wt");

const int MAX = 100005;
vector<int> t(MAX);
int n, m, tmp, x, y, i;

int radacina(int x) {
    int r;
    for (r = x; t[r] != 0; r = t[r])
        ;
    return r;
}

void connect(int x, int y) {
    t[radacina(x)] = radacina(y);
}

int main() {
    if (fscanf(fin, "%d%d", &n, &m)) ;
    for (i=1; i<=m; ++i) {
        if (fscanf(fin, "%d%d%d", &tmp, &x, &y)) ;
        if (tmp == 1)
            connect(x, y);
        else
            if (radacina(x) == radacina(y))
                fprintf(fout, "DA\n");
            else
                fprintf(fout, "NU\n");
    }
    return 0;
}