LeetCode 198. 打家劫舍

题目描述

🔥 198. 打家劫舍

思路分析

dp[i] 表示偷取前 i 个房屋所能获得的最大金额

参考代码

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
func rob(nums []int) int {
	if len(nums) == 0 {
		return 0
	}

	if len(nums) == 1 {
		return nums[0]
	}

	// dp[i] 表示偷取前 i 个房屋所能获得的最大金额
	dp := make([]int, len(nums))
	dp[0] = nums[0]
	dp[1] = max(nums[0], nums[1])

	for i := 2; i < len(nums); i++ {
		// 对于第 i 个房屋,有两种选择:
		// 1. 不抢劫第 i 个房屋,最大财宝数量等于前一个房屋的最大财宝数量 dp[i-1]
		// 2. 抢劫第 i 个房屋,最大财宝数量等于前两个房屋的最大财宝数量加上第 i 个房屋的财宝数量 nums[i]
		dp[i] = max(dp[i-1], dp[i-2]+nums[i])
	}

	return dp[len(nums)-1]
}

func max(a, b int) int {
	if a > b {
		return a
	}
	return b
}

🍏 点击查看 Java 题解

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
class Solution {
    public int rob(int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }
        int n = nums.length;
        if (n == 1) {
            return nums[0];
        }
        int[] dp = new int[n]; // dp[i] 表示偷窃前 i 个房屋所能获得的最高金额
        dp[0] = nums[0];
        dp[1] = Math.max(nums[0], nums[1]);
        for (int i = 2; i < n; i++) {
            dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);
        }
        return dp[n - 1];
    }
}

相似题目

题目 难度 题解
乘积最大子数组 Medium  
打家劫舍 II Medium  
粉刷房子 Medium  
栅栏涂色 Medium  
打家劫舍 III Medium  
不含连续 1 的非负整数 Hard  
金币路径 Hard  
删除并获得点数 Medium  
本文作者:
本文链接: https://hgnulb.github.io/blog/30989935
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处!