Pagini recente » Cod sursa (job #1733608) | Cod sursa (job #2915008) | Cod sursa (job #1744334) | Cod sursa (job #2574027) | Cod sursa (job #2543632)
#include <fstream>
using namespace std;
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int n, m, t[100005];
void init()
{
for(int i=1; i<=n; i++)
t[i]=i;
}
int parcurgere(int x)
{
if(t[x]==x)
return x;
int rad=parcurgere(t[x]);
t[x]=rad;
return rad;
}
int main()
{
f>>n>>m;
init();
int x, y, c;
for(int i=1; i<=m; i++)
{
f>>c>>x>>y;
if(c==2)
{
if(parcurgere(x)==parcurgere(y))
g<<"DA";
else g<<"NU";
g<<'\n';
}
else
{
t[parcurgere(y)]=parcurgere(x);
}
}
return 0;
}