Pagini recente » Cod sursa (job #2379651) | Cod sursa (job #1950106) | Cod sursa (job #134191) | Cod sursa (job #794569) | Cod sursa (job #1722859)
#include<fstream>
#include<iostream>
#define elemax 100002
using namespace std;
ifstream si("disjoint.in");
ofstream so("disjoint.out");
int rad[elemax];
int tata(int x)
{
while(rad[x]!=rad[rad[x]])
rad[x]=rad[rad[x]];
return rad[x];
}
bool query(int a,int b)
{
int t1,t2;
t1=tata(a);
t2=tata(b);
return (t1==t2);
}
// Uneste multimea lui a cu multimea lui b
inline void uneste(int a,int b)
{
int t1=tata(a),t2=tata(b);
if((a+b)&1)
rad[t2]=rad[t1];
else
rad[t1]=rad[t2];
}
int main()
{
int n,m;
si>>n>>m;
int a,b,c,i;
for(i=1;i<=n;++i)
{
rad[i]=i;
}
for(i=0;i<m;++i)
{
si>>a>>b>>c;
if(a==1)
uneste(b,c);
else
{
if(query(b,c))
so<<"DA"<<'\n';
else
so<<"NU"<<'\n';
}
}
si.close();
so.close();
return 0;
}