๐ŸŒ— 213. ๆ‰“ๅฎถๅŠซ่ˆ II

ๅžไฝ›็ซฅๅญ2022ๅนด6ๆœˆ9ๆ—ฅๅฐไบŽ 1 ๅˆ†้’Ÿ

๐ŸŒ— 213. ๆ‰“ๅฎถๅŠซ่ˆ II

้šพๅบฆ: ๐ŸŒ—

้—ฎ้ข˜ๆ่ฟฐ

img_35.png


่งฃๆณ•

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;
    }
}

่พ“ๅ‡บ

img_34.png

ไธŠๆฌก็ผ–่พ‘ไบŽ: 2022/6/20 ไธ‹ๅˆ8:24:47
่ดก็Œฎ่€…: liuxianzhishou