leetcodeSolution to some Leetcode problems written in C++ |
git clone git://git.dimitrijedobrota.com/leetcode.git |
Log | Files | Refs | README | LICENSE |
1824.cpp (751B)
0 class Solution {
1 public:
2 int minSideJumps(const vector<int> &obstacles) const {
3 static unsigned dp[500002][3];
4 const int n = size(obstacles);
6 memset(dp, 0xF0, sizeof(dp));
7 memset(dp[n - 1], 0x00, sizeof(dp[n]));
8 for (int i = n - 2; i >= 0; i--) {
9 for (int j = 0; j < 3; j++) {
10 if (obstacles[i + 1] == j + 1) continue;
11 if (obstacles[i] == j + 1) continue;
12 dp[i][j] = dp[i + 1][j];
13 }
15 dp[i][0] = min({dp[i][0], dp[i][1] + 1, dp[i][2] + 1});
16 dp[i][1] = min({dp[i][1], dp[i][0] + 1, dp[i][2] + 1});
17 dp[i][2] = min({dp[i][2], dp[i][0] + 1, dp[i][1] + 1});
18 }
20 return dp[0][1];
21 }
22 };