๐ 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;
    }
}
่พๅบ
