Pagini recente » Cod sursa (job #2134684) | Cod sursa (job #3191812) | Cod sursa (job #1876516) | Cod sursa (job #450821) | Cod sursa (job #411484)
Cod sursa(job #411484)
#include<fstream.h>
int main()
{
int op,m,n,x,y,cx,cy,i,padre[100100],vy[20000],vx[20000];
ifstream f("disjoint.in");
ofstream g("disjoint.out");
f>>n>>m;
for(i=1;i<=n;i++)
padre[i]=i;
while(m--)
{
f>>op>>x>>y;
if(op==1)
{
cx=0;
cy=0;
while(x!=padre[x])
{
x=padre[x];
vx[++cx]=x;
}
while(y!=padre[y])
{
y=padre[y];
vy[++cy]=y;
}
if(cx>cy)
{
for(i=1;i<=cy;i++)
padre[vy[i]]=x;
padre[y]=x;
}
else
{
for(i=1;i<=cx;i++)
padre[vx[i]]=y;
padre[x]=y;
}
}
else
{
while(x!=padre[x])
x=padre[x];
while(y!=padre[y])
y=padre[y];
if(x==y)
g<<"DA\n";
else
g<<"NU\n";
}
}
return 0;
}