Pagini recente » Cod sursa (job #1308773) | Cod sursa (job #3201429) | Cod sursa (job #855797) | Cod sursa (job #3186104) | Cod sursa (job #2158566)
#include <iostream>
#include <fstream>
#define nmax 100001
using namespace std;
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
int t[nmax],h[nmax],rx,ry,z,x,n,m,c,y;
int Find(int x)
{
int rx=x,z;
while(t[rx])
rx=t[rx];
while(x!=rx)
{
z=t[x];
t[x]=rx;
x=z;
}
return rx;
}
void Union(int rx, int ry)
{
if(h[rx]==h[ry])
{
h[rx]++;
t[rx]=ry;
}
else if(h[rx]<h[ry])
{
t[rx]=ry;
}
else t[ry]=rx;
}
void solve()
{
while(m--)
{
fin>>c>>x>>y;
rx=Find(x);
ry=Find(y);
if(c==1) Union(rx,ry);
else
{
if(rx==ry) fout<<"DA"<<'\n';
else fout<<"NU"<<'\n';
}
}
}
int main()
{
fin>>n>>m;
solve();
return 0;
}