Pagini recente » Cod sursa (job #2581628) | Cod sursa (job #2197490) | Cod sursa (job #2654936) | Cod sursa (job #1900012) | Cod sursa (job #2718872)
#include <iostream>
#include <fstream>
#include <algorithm>
#include <vector>
#include <queue>
#include <stack>
#include <cstring>
using namespace std;
#define NMAX 1000005
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
int tati[NMAX], i, j, n, m, v, x, y;
int radacina(int nod)
{
if(tati[nod]==0)
return nod;
else
{
int x=radacina(tati[nod]);
tati[nod]=x;
return x;
}
}
int main()
{
fin>>n>>m;
for(i=1; i<=m; i++)
{
fin>>v>>x>>y;
int rx=radacina(x);
int ry=radacina(y);
if(v==1)
{
if(rx!=ry)
{
tati[ry]=rx;
}
}
else
{
if(rx==ry)
fout<<"DA"<<'\n';
else
fout<<"NU"<<'\n';
}
}
return 0;
}