Pagini recente » Cod sursa (job #2886591) | Cod sursa (job #1076739)
#include <fstream>
using namespace std;
int n,m,t[100001],h[100001];
int root(int n)
{
int r=n,i;
while(t[n])
n=t[n];
while(t[r])
{
i=t[r];
t[r]=n;
r=i;
}
return n;
}
inline void Unite(int a,int b)
{
if(h[a]<h[b])
t[a]=b;
else if(h[a]>h[b])
t[a]=b;
else
{
t[a]=b;
h[b]++;
}
}
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
int main()
{
int o,a,b;
fin>>n>>m;
while(m--)
{
fin>>o>>a>>b;
if(o==1)
Unite(root(b),root(a));
else if(root(a)==root(b))
fout<<"DA\n";
else
fout<<"NU\n";
}
return 0;
}