Pagini recente » Cod sursa (job #2757603) | Cod sursa (job #1217292) | Cod sursa (job #345379) | Cod sursa (job #2196034) | Cod sursa (job #1933204)
// var II cu compresia drumurilor
#include <fstream>
using namespace std;
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int T[100001];//vectorul de tati(T[] )
int i,n,m,x,y,op;
int rad(int x)
{
int r, y;
r=x; //merg in sus pe arbore pana gasesc radacina
while(T[r]!=0)r=T[r];// un nod cu tata 0)
while(T[x]!=0) //aplic compresia drumurilor
{ y = T[x]; T[x] = r; x = y; }
return r; //returnez radacina
}
void reuneste( int x,int y)
{
T[y]=x;
}
int main()
{
f>>n>>m;
for(i=1;i<=m;i++)
{
f>>op>>x>>y;
if (op==2) { if(rad(x)==rad(y)) g<<"DA\n";
else g<<"NU\n";}
else reuneste(rad(x),rad(y));
}
return 0;
}