Pagini recente » Cod sursa (job #1772649) | Cod sursa (job #2113991) | Arhiva de probleme | Cod sursa (job #1761144) | Cod sursa (job #1305931)
#include<fstream>
using namespace std;
long t[100001];
long q(int x)
{
int a,b;
for (a=x;t[a]!=a;a=t[a]);
while(t[x]!=x)
{
b=t[x];
t[x]=a;
x=b;
}
return a;
}
int main()
{
ifstream f("disjoint.in");
ofstream g("disjoint.out");
long x,y,n,m,i,j,c;
f>>n>>m;
for(i=1;i<=n;i++)
t[i]=i;
for(i=1;i<=m;i++)
{
f>>c>>x>>y;
if(c==1)
{
int d,e;
d=q(x);
e=q(y);
if(d<e)
t[d]=e;
else t[e]=d;
}
else{
x=q(x);
y=q(y);
if(t[x]==t[y])
g<<"DA\n";
else g<<"NU\n";
}
}
f.close();
g.close();
return 0;
}