213. House Robber II
Input: [2,3,2]
Output: 3
Explanation: You cannot rob house 1 (money = 2) and then rob house 3 (money = 2),
because they are adjacent houses.Input: [1,2,3,1]
Output: 4
Explanation: Rob house 1 (money = 1) and then rob house 3 (money = 3).
Total amount you can rob = 1 + 3 = 4.class Solution {
public int rob(int[] nums) {
if (nums == null || nums.length == 0) return 0;
int len = nums.length;
if (len == 1) return nums[0];
if (len == 2) return Math.max(nums[0], nums[1]);
return Math.max(helper(nums, 0, len - 2), helper(nums, 1, len - 1));
}
private int helper(int[] nums, int s, int e) {
if (s == e) return nums[s];
int dp[] = new int[nums.length];
dp[s] = nums[s];
dp[s + 1] = Math.max(nums[s + 1], nums[s]);
for (int i = s + 2; i <= e; i++) {
dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i]);
};
return dp[e];
}
}Last updated