Cod sursa(job #3264595)

Utilizator Horia123144Musat Horia Gabriel Horia123144 Data 22 decembrie 2024 17:29:29
Problema Paduri de multimi disjuncte Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.62 kb
#include <bits/stdc++.h>
#define nmax 100005
using namespace std;
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
int n,m,t[nmax],task,a,b;
int get_root(int x)
{
    while(t[x]!=0)
        x=t[x];
    return x;
}
void join(int x,int y)
{
    int rx=get_root(x),ry=get_root(y);
    t[ry]=rx;
}
int main()
{
    fin>>n>>m;
    while(m--)
    {
        fin>>task>>a>>b;
        if(task==1)
            join(a,b);
        else
        {
            if(get_root(a)==get_root(b))
                fout<<"DA"<<'\n';
            else
                fout<<"NU"<<'\n';
        }
    }
    return 0;
}