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];
    }
相关推荐
onlyzzr5 分钟前
Leetcode Hot100 第58题 23.合并K个升序链表
java·算法·leetcode
修己xj6 分钟前
算法系列之回溯算法求解数独及所有可能解
算法
axxy200017 分钟前
C++ Primer Plus第十二章课后习题总结
c++
剑海风云32 分钟前
73. 矩阵置零
java·数据结构·算法·矩阵
十年一梦实验室1 小时前
【C++】 嵌套类(Nested Class)
开发语言·c++
冠位观测者1 小时前
【Leetcode 每日一题】3306. 元音辅音字符串计数 II
数据结构·算法·leetcode
矛取矛求1 小时前
C++ 模板初阶总结
开发语言·c++
withoutfear1 小时前
不同AI生成的PHP版雪花算法
算法·php·ai编程
lrydnh1 小时前
MFCday01、模式对话框
c++
自由的晚风1 小时前
脑电波控制设备:基于典型相关分析(CCA)的脑机接口频率精准解码方法
人工智能·经验分享·笔记·算法·matlab·脑机接口·ssvep