-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathAvoid Explosion.cpp
58 lines (54 loc) · 1.51 KB
/
Avoid Explosion.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
class Solution {
public:
int rnk[10005], par[10005];
void make_set(int n) {
for (int i = 0; i < n; i++) {
par[i] = i;
rnk[i] = 1;
}
}
int find_set(int x) {
if (par[x] == x) return x;
return par[x] = find_set(par[x]);
}
void union_set(int a, int b) {
int p1 = find_set(a);
int p2 = find_set(b);
if (p1 == p2) return;
if (rnk[p1] > rnk[p2]) {
par[p2] = p1;
rnk[p1] += rnk[p2];
} else {
par[p1] = p2;
rnk[p2] += rnk[p1];
}
}
vector<string> avoidExplosion(vector<vector<int>> mix, int n,
vector<vector<int>> danger, int m) {
make_set(n + 1);
vector<string> ans(n);
for (int i = 0; i < n; i++) {
int item1 = mix[i][0];
int item2 = mix[i][1];
int ok = 1;
int p1 = find_set(item1);
int p2 = find_set(item2);
for (int j = 0; j < m; j++) {
int par1 = find_set(danger[j][0]);
int par2 = find_set(danger[j][1]);
if (max(par1, par2) == max(p1, p2) and
min(par1, par2) == min(p1, p2)) {
ok = 0;
break;
}
}
if (ok) {
ans[i] = "Yes";
union_set(p1, p2);
} else {
ans[i] = "No";
}
}
return ans;
}
};