leetcode198 C++ 4ms 打家劫舍
class Solution {
public:
int rob(vector<int>& nums) {
if( nums.empty()){
return 0;
}
if( nums.size() == 1){
return nums[0];
}
vector<int> dp(nums.size(), 0);
dp[0] = nums[0];
dp[1] = nums[1] > nums[0] ? nums[1]: nums[0];
for(int i=2; i < nums.size(); i++){
dp[i] = dp[i-1] > dp[i-2] + nums[i] ? dp[i-1] : dp[i-2] + nums[i];
}
return dp[dp.size()-1];
}
};