Pagini recente » Cod sursa (job #2176386) | Cod sursa (job #1724989) | Cod sursa (job #1737968) | Cod sursa (job #776045) | Cod sursa (job #2280053)
#include <bits/stdc++.h>
using namespace std;
ifstream fin("disjoint.in");
ofstream fout("disjoint.out");
vector <int> v[100005];
int p[100005],cod,x,y;
void dfs(int nod)
{
for(auto it=v[nod].begin();it!=v[nod].end();it++)
{
int nxt=*it;
if(p[nxt]!=p[x])
{
v[p[x]].push_back(nxt);
p[nxt]=p[x];
dfs(nxt);
}
}
}
int main()
{
int n,m;
fin>>n>>m;
for(int i=1;i<=n;i++)
p[i]=i;
for(int i=1;i<=m;i++)
{
fin>>cod>>x>>y;
if(cod==1)
{
p[y]=p[x];
v[p[x]].push_back(y);
dfs(y);
}
else
if(p[y]==p[x])
fout<<"DA"<<'\n';
else
fout<<"NU"<<'\n';
}
return 0;
}