leetcode_198_打家劫舍


思路 :首先定义一个数组对于dp[i]读作1->i能获取的最大利益,第i个房屋只有"偷"和不"偷"两种情况,分别进行讨论

"偷": 既然"偷"了 i那就肯定不能偷i-1 了,但是为了使"偷"的尽可能多除了必须不能"偷"的全要"偷",

所以得到第一个部分dp[i]=nums[i]+dp[i-2];

不"偷" : 这就很明显了不"偷"那就是前[i-1]个的情况嘛dp[i]=dp[i-1];

综上实现公式应为dp[i]=max(nums[i]+dp[i-2],dp[i-1]);

实现代码如下

cpp 复制代码
int rob(vector<int>& nums) {
        int dp[105], size = nums.size();
        dp[0] = nums[0];
        if (size > 1)
            dp[1] = max(nums[0], nums[1]);
        for (int i = 2; i < size; i++) {
            dp[i] = max(nums[i] + dp[i - 2], dp[i - 1]);
        }
        return dp[size - 1];
    }
相关推荐
Wect4 小时前
LeetCode 5. 最长回文子串:DP + 中心扩展
前端·算法·typescript
一只牛_0074 小时前
pthread亲和性继承的一个坑:main绑核让整个进程退化到单核
c++
糖果店的幽灵4 小时前
决策树详解与sklearn实战
算法·决策树·sklearn
Lewiis4 小时前
趣谈排序算法
算法·排序算法
ComputerInBook5 小时前
数字图像处理(4版)——第 8 章——图像压缩与水印(上)(Rafael C.Gonzalez&Richard E. Woods)
人工智能·算法·计算机视觉·图像压缩·图像水印
刀法如飞5 小时前
Python列表去重:从新手三连到高阶特技,20种解法全收录
python·算法·编程语言
minji...5 小时前
算法题 动态规划
算法·动态规划
张健11564096485 小时前
C++访问控制与友元
java·开发语言·c++
水蓝烟雨5 小时前
3337. 字符串转换后的长度 II
算法·leetcode
MegaDataFlowers5 小时前
SiliconCompiler workflow
算法