Pagini recente » Cod sursa (job #2954735) | Cod sursa (job #3215219) | Cod sursa (job #2483471) | Cod sursa (job #1817525) | Cod sursa (job #1894337)
#include <iostream>
#include <fstream>
using namespace std;
#define no 100002
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int v[no],c,n,m,a,b,i,rg[no];
int main()
{
f>>n>>m;
for(i=1;i<=n;i++)
v[i]=i,rg[i]=1;
for(i=1;i<=m;i++)
{
f>>c>>a>>b;
if(c==1) {
while(v[a]!=a)a=v[a];
while(v[b]!=b)b=v[b];
if(rg[a]>rg[b]) v[b]=a;
else v[a]=b;
if(rg[a]==rg[b])rg[b]++;
}
else{
while(v[a]!=a)a=v[a];
while(v[b]!=b)b=v[b];
if(b==a) g<<"DA"<<'\n'; else g<<"NU"<<'\n';
}
}
}