Cod sursa(job #1160162)
| Utilizator | Data | 30 martie 2014 12:27:36 | |
|---|---|---|---|
| Problema | Paduri de multimi disjuncte | Scor | 100 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.57 kb |
#include <fstream>
using namespace std;
#define NMax 100005
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int n,m;
int tata[NMax];
int query(int x)
{
if(!tata[x]) return x;
else {tata[x]=query(tata[x]); return tata[x];}
}
void update(int x,int y)
{
if(x<y) tata[x]=y;
else tata[y]=x;
}
int main()
{
int i,cod,x,y;
f>>n>>m;
for(i=1;i<=m;i++)
{
f>>cod>>x>>y;
if(cod==1) update(query(x),query(y));
else { if(query(x)==query(y)) g<<"DA\n"; else g<<"NU\n";}
}
f.close();
g.close();
return 0;
}
