Pagini recente » Cod sursa (job #1174330) | Cod sursa (job #788002) | Cod sursa (job #1635524) | Cod sursa (job #2672890) | Cod sursa (job #2944060)
#include <fstream>
using namespace std;
ifstream in("disjoint.in");
ofstream out("disjoint.out");
int n, m, colors[100001], minim, mult1, mult2;
int check(int nod){
minim = min(minim, colors[nod]);
if(colors[nod] == nod){
return minim;
}
check(colors[nod]);
colors[nod] = minim;
return colors[nod];
}
int main() {
in >> n >> m;
for(int i = 1; i <= n; i++){
colors[i] = i;
}
int nr, a, b;
while(m--){
in >> nr >> a >> b;
if(nr == 1){
colors[max(a,b)] = colors[min(a, b)];
}
else
{
minim = a;
mult1 = check(a);
minim = b;
mult2 = check(b);
out << (mult1 == mult2 ? "DA" : "NU") << '\n';
}
}
return 0;
}