Pagini recente » Cod sursa (job #2332328) | Cod sursa (job #1140365) | Cod sursa (job #922249) | Istoria paginii runda/oni_2007_ziua1_clasele_xi-xii/clasament | Cod sursa (job #2471685)
///Var 3
///Reuniunea dupa rang: Pentru fiecare multime tinem minte inaltimea arborelui care reprezinta acea multime
///si atunci cand vrem sa unim 2 arbori, il unim pe cel mai mic de cel mai mare.
///Compresia drumurilor
#include <bits/stdc++.h>
#define K 100002
using namespace std;
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int t[K],h[K];
int tata (int x)
{
if(t[x]==0)
return x;
return tata(t[x]);
}
void compresie(int tt,int fiu)
{
if(fiu==tt)return ;
t[fiu]=tt;
compresie(tt,t[fiu]);
}
int main()
{
int i,n,m,cod,x,y,tx,ty;
f>>n>>m;
for(i=1;i<=n;i++)
t[i]=0,h[i]=1;
while(m--)
{
f>>cod>>x>>y;
if(cod==2)
if(tata(x)==tata(y))
g<<"DA\n";
else g<<"NU\n";
else
{
tx=tata(x);ty=tata(y);
if(h[tx] < h[ty])///Reuniunea dupa rang:
{
swap(tx,ty);
swap(x,y);
}
t[ty]=tx;
h[tx]=max(h[tx],h[ty]+1);
compresie(tx,y);
}
}
}