题目

思路:动态规划
- 环形的话,第一个房子和最后一个房子,不能同时考虑。
- 把环拆成两个队列,一个是从0到n-1,另一个是从1到n,然后返回两个结果最大的。

代码
class Solution {
public int rob(int[] nums) {
if (nums.length == 1) {
return nums[0];
}
if (nums.length == 2) {
return Math.max(nums[0], nums[1]);
}
int[] dp1 = new int[nums.length - 1];
int[] dp2 = new int[nums.length - 1];
dp1[0] = nums[0];
dp2[0] = nums[1];
dp1[1] = Math.max(nums[0], nums[1]);
dp2[1] = Math.max(nums[1], nums[2]);
for (int i = 2; i <= nums.length - 2; i++) {
dp1[i] = Math.max(dp1[i - 2] + nums[i], dp1[i - 1]);
}
for (int i = 2; i <= nums.length - 2; i++) {
dp2[i] = Math.max(dp2[i - 2] + nums[i + 1], dp2[i - 1]);
}
int max1 = 0;
for (int x : dp1) {
max1 = Math.max(max1, x);
}
int max2 = 0;
for (int x : dp2) {
max2 = Math.max(max2, x);
}
return Math.max(max1, max2);
}
}