简单的动态规划题目
dp[i] = max((dp[i-2]+nums[i]),dp[i-1])
要注意i比较小的情况
class Solution {
public:
int rob(vector<int>& nums) {
vector<int> dp(nums.size(),0);
if(nums.size() == 0) return 0;
if(nums.size() == 1) return nums[0];
if(nums.size() == 2) return (nums[0] > nums[1] ? nums[0] : nums[1]);
dp[0] = nums[0];
dp[1] = nums[0] > nums[1] ? nums[0] : nums[1];
for(int i = 2 ; i< nums.size();++i)
{
dp[i] = max((dp[i-2]+nums[i]),dp[i-1]);
}
return dp[nums.size()-1];
}
};