一、题目
二、思路
1、动态规划,要么选要么不选,dp[i]可以从max(dp[i-2]+nums[i],dp[i-1]);来
三、代码
class Solution {
public:
int rob(vector<int>& nums) {
int size=nums.size();
if(size==0){
return 0;
}
else if(size==1){
return nums[0];
}
else if(size==2){
return max(nums[0],nums[1]);
}
vector<int>dp(size,0);
dp[0]=nums[0];
dp[1]=max(dp[0],nums[1]);
//int Count=max(dp[0],dp[1]);
for(int i=2;i<size;++i){
dp[i]=max(dp[i-2]+nums[i],dp[i-1]);
//Count=max(Count,dp[i]);
}
return dp[size-1];
}
};