Cod sursa(job #3317633)

Utilizator Petre_TimoteiPetre Timotei Daniel Petre_Timotei Data 24 octombrie 2025 17:51:50
Problema Paduri de multimi disjuncte Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.7 kb
#include <fstream>
using namespace std;
ifstream cin("disjoint.in");
ofstream cout("disjoint.out");
int sef[100001] ,n ,m ,o,x,y;
int boss(int x)
{
    if(sef[x]==x)
        return x;
    else
        return sef[x]=boss(sef[x]);
}
void unire(int x ,int y)
{
    int sef_x=boss(x);
    int sef_y=boss(y);
    sef[sef_y]=sef_x;
}
int main()
{
    cin>>n>>m;
    for(int i=1;i<=n;i++)
        sef[i]=i;
      for(int i=1;i<=m;i++)
      { cin>>o>>x>>y;
           if(o==1)
            unire(x,y);
           if(o==2)
           { if(boss(x)==boss(y))
                cout<<"DA"<<'\n';
                   else
                 cout<<"NU"<<'\n';
           }

      }
    return 0;
}