Cod sursa(job #566506)

Utilizator aplace4uheadaplace4uhead aplace4uhead Data 29 martie 2011 09:27:18
Problema Paduri de multimi disjuncte Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream.h>
#define NM 100//010

ifstream in("disjoint.in");
ofstream out("disjoint.out");



int t[NM],i,j,n,m,o,a,b,rang[NM];

int multime(int i)
{
	if(i == t[i])
		return i;
	return multime(t[i]);
}

void reuneste(int a, int b)
{
	int i,j;
	i=multime(a);
	j=multime(b);
	if(i==j)
		return;
	if(rang[i]<rang[j])
		t[i]=j;
	else
		t[j]=i;
	if(rang[i]==rang[j])
		rang[i]++;
}

int main()
{
	in>>n>>m;
	for(i=1;i<=n;i++)
		t[i] = i;
	for(i=1;i<=m;i++)
	{
		in>>o>>a>>b;
		if(o==1)
			reuneste(a,b);
		else
			out<<(multime(a)==multime(b) ? "DA" : "NU")<<'\n';
	}

	return 0;
}