Cod sursa(job #2122537)
| Utilizator | Data | 5 februarie 2018 11:06:39 | |
|---|---|---|---|
| Problema | Paduri de multimi disjuncte | Scor | 40 |
| Compilator | cpp | Status | done |
| Runda | Arhiva educationala | Marime | 0.62 kb |
#include <iostream>
#include <fstream>
#include <cmath>
using namespace std;
ifstream f("disjoint.in");
ofstream g("disjoint.out");
int n, m, c, a[100005], s1, s2;
int main()
{
int i, j, x, y;
f>>n>>m;
for (i=1; i<=n; i++)
a[i]=i;
for (i=1; i<=m; i++)
{
f>>c>>x>>y;
if (c==1)
{
s1=min(a[x], a[y]);
s2=a[x]+a[y]-s1;
for (j=1; j<=n; j++)
if (a[j]==s2) a[j]=s1;
}
else
{
if (a[x]==a[y]) g<<"DA"<<"\n";
else g<<"NU"<<"\n";
}
}
return 0;
}
