题目
提示:
1 <= nums.length <= 100
0 <= nums[i] <= 400
题解
动态规划
可参考官方解题步骤
代码
class Solution {
public:
int rob(vector<int>& nums) {
int n=nums.size();
if(n<=0)
return 0;
if(n==1)
return nums[0];
vector<int> dp(n);
dp[0]=nums[0];
dp[1]=max(nums[0],nums[1]);
for(int i=2;i<n;i++){
dp[i]=max(dp[i-1],dp[i-2]+nums[i]);
}
return dp[n-1];
}
};
class Solution {
public:
int rob(vector<int>& nums) {
int n=nums.size();
if(n<=0)
return 0;
if(n==1)
return nums[0];
if(n==2)
return max(nums[0],nums[1]);
int p=nums[0];
int q=max(nums[0],nums[1]);
int r;
for(int i=2;i<n;i++){
r=max(q,p+nums[i]);
p=q;
q=r;
}
return r;
}
};