AlgoMaster Logo

House Robber

nums=[1, 2, 3, 1]
1public int rob(int[] nums) {
2    int n = nums.length;
3    if (n == 0) return 0;
4    if (n == 1) return nums[0];
5
6    int[] dp = new int[n];
7    dp[0] = nums[0];
8    dp[1] = Math.max(nums[0], nums[1]);
9
10    for (int i = 2; i < n; i++) {
11        dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);
12    }
13
14    return dp[n - 1];
15}
0 / 9
houses:01122331dp:0?1?2?3?