๐ 213. ๆๅฎถๅซ่ II
2022ๅนด6ๆ9ๆฅๅฐไบ 1 ๅ้
๐ 213. ๆๅฎถๅซ่ II
้พๅบฆ: ๐
้ฎ้ขๆ่ฟฐ
่งฃๆณ
class Solution {
public int rob(int[] nums) {
// ๆ่ทฏ๏ผ
// ๅไธคๆฌก้ๅ
// ็ฌฌไธๆฌกๆถต็ [0, len - 2] ๅฎถๆฟๅฑ
// ็ฌฌไบๆฌกๆถต็ [1, len - 1] ๅฎถๆฟๅฑ
int len = nums.length;
// ็นๆฎๆ
ๅต็นๅค
if(len == 1) {
return nums[0];
}
// len >= 2
int res = 0;
int[][] dp = new int[len - 1][2];
dp[0][1] = nums[0];
for(int i = 1; i < len - 1; i ++) {
dp[i][0] = Math.max(dp[i - 1][0], dp[i - 1][1]);
dp[i][1] = dp[i - 1][0] + nums[i];
}
res = Math.max(dp[len - 2][0], dp[len - 2][1]);
dp[0][0] = 0;
dp[0][1] = nums[1];
for(int i = 1; i < len - 1; i ++) {
dp[i][0] = Math.max(dp[i - 1][0], dp[i - 1][1]);
dp[i][1] = dp[i - 1][0] + nums[i + 1];
}
res = Math.max(res, Math.max(dp[len - 2][0], dp[len - 2][1]));
return res;
}
}