解法
class Solution {
public int rob(int[] nums) {
int len = nums.length;
// 考虑取位置i上的元素时,能拿到的最大值
int[] dp = new int[len + 1];
dp[0] = 0;
dp[1] = nums[0];
for (int i = 2; i <= len; i++) {
// 考虑取dp[i-1],这时候不能加当前值了
// 考虑取dp[i-2]加上当前值
dp[i] = Math.max(dp[i - 1], dp[i - 2] + nums[i - 1]);
}
return dp[len];
}
}
网友评论