-
-
Notifications
You must be signed in to change notification settings - Fork 8.9k
/
Copy pathSolution.cpp
85 lines (82 loc) · 2.61 KB
/
Solution.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
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
class Solution {
public:
const vector<int> dirs = {-1, 0, 1, 0, -1};
vector<int> c;
vector<vector<int>> areas;
vector<unordered_set<int>> boundaries;
vector<vector<int>> infected;
vector<vector<bool>> vis;
int m;
int n;
int containVirus(vector<vector<int>>& isInfected) {
infected = isInfected;
m = infected.size();
n = infected[0].size();
vis.assign(m, vector<bool>(n));
int ans = 0;
while (1) {
for (int i = 0; i < m; ++i)
for (int j = 0; j < n; ++j) vis[i][j] = false;
c.clear();
areas.clear();
boundaries.clear();
for (int i = 0; i < m; ++i) {
for (int j = 0; j < n; ++j) {
if (infected[i][j] == 1 && !vis[i][j]) {
c.push_back(0);
areas.push_back({});
boundaries.push_back({});
dfs(i, j);
}
}
}
if (areas.empty()) break;
int idx = getMax();
ans += c[idx];
for (int t = 0; t < areas.size(); ++t) {
if (t == idx) {
for (int v : areas[t]) {
int i = v / n, j = v % n;
infected[i][j] = -1;
}
} else {
for (int v : areas[t]) {
int i = v / n, j = v % n;
for (int k = 0; k < 4; ++k) {
int x = i + dirs[k], y = j + dirs[k + 1];
if (x >= 0 && x < m && y >= 0 && y < n && infected[x][y] == 0) infected[x][y] = 1;
}
}
}
}
}
return ans;
}
int getMax() {
int idx = 0;
int mx = boundaries[0].size();
for (int i = 1; i < boundaries.size(); ++i) {
int t = boundaries[i].size();
if (mx < t) {
mx = t;
idx = i;
}
}
return idx;
}
void dfs(int i, int j) {
vis[i][j] = true;
areas.back().push_back(i * n + j);
for (int k = 0; k < 4; ++k) {
int x = i + dirs[k], y = j + dirs[k + 1];
if (x >= 0 && x < m && y >= 0 && y < n) {
if (infected[x][y] == 1 && !vis[x][y])
dfs(x, y);
else if (infected[x][y] == 0) {
c.back() += 1;
boundaries.back().insert(x * n + y);
}
}
}
}
};