题目:你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。
给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。
解题思路:
如果你对于动态规划还不是很了解,或者没怎么做过动态规划的题目的话,那么 House Robber (小偷问题)这道题是一个非常好的入门题目。本文会以 House Robber 题目为例子,讲解动态规划题目的四个基本步骤。
动态规划的的四个解题步骤是:
定义子问题
写出子问题的递推关系
确定 DP 数组的计算顺序
空间优化(可选)
class Solution {
public:
int rob(vector<int>& nums) {
if(nums.empty())
return 0;
int temp=0;
int pre = 0;
int cur = nums[0];
for(int i=2;i<=nums.size();i++)
{
temp = max(cur,pre+nums[i-1]);
pre = cur;
cur = temp;
}
return cur;
}
};
使用滚动数组的方法,减小空间。