forked from MaskRay/LeetCode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathpacific-atlantic-water-flow.cc
53 lines (52 loc) · 1.44 KB
/
pacific-atlantic-water-flow.cc
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
// Pacific Atlantic Water Flow
#define FOR(i, a, b) for (remove_cv<remove_reference<decltype(b)>::type>::type i = (a); i < (b); i++)
#define REP(i, n) FOR(i, 0, n)
class Solution {
public:
vector<pair<int, int>> pacificAtlantic(vector<vector<int>>& matrix) {
if (matrix.empty())
return {};
int m = matrix.size(), n = matrix[0].size();
queue<pair<int, int>> q;
vector<vector<char>> a(m, vector<char>(n, 0));
auto bfs = [&](int b) {
while (q.size()) {
int x, y;
tie(x, y) = q.front();
q.pop();
if (x && ! (a[x-1][y] & b) && matrix[x][y] <= matrix[x-1][y])
a[x-1][y] |= b, q.emplace(x-1, y);
if (x+1 < m && ! (a[x+1][y] & b) && matrix[x][y] <= matrix[x+1][y])
a[x+1][y] |= b, q.emplace(x+1, y);
if (y && ! (a[x][y-1] & b) && matrix[x][y] <= matrix[x][y-1])
a[x][y-1] |= b, q.emplace(x, y-1);
if (y+1 < n && ! (a[x][y+1] & b) && matrix[x][y] <= matrix[x][y+1])
a[x][y+1] |= b, q.emplace(x, y+1);
}
};
REP(i, m) {
q.emplace(i, 0);
a[i][0] = 1;
}
FOR(i, 1, n) {
q.emplace(0, i);
a[0][i] = 1;
}
bfs(1);
REP(i, m) {
q.emplace(i, n-1);
a[i][n-1] |= 2;
}
REP(i, n-1) {
q.emplace(m-1, i);
a[m-1][i] |= 2;
}
bfs(2);
vector<pair<int, int>> r;
REP(i, m)
REP(j, n)
if (a[i][j] == 3)
r.emplace_back(i, j);
return r;
}
};