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];
    }
相关推荐
云泽8083 分钟前
蓝桥杯算法精讲:深剖分治算法及其经典应用
算法·职场和发展·蓝桥杯
志摩凛4 分钟前
范畴论——前端与计算机领域的“抽象工具箱”:该用则用,该弃则弃
算法·架构
2401_857918296 分钟前
C++与自动驾驶系统
开发语言·c++·算法
乐分启航9 分钟前
【无标题】
深度学习·算法·目标检测·transformer·迁移学习
liu****16 分钟前
linux上git推送内容到gitee上
c++·git·gitee·版本控制
GfovikS0610017 分钟前
C++中的函数式编程
开发语言·c++·算法
2401_8579182918 分钟前
C++中的构建器模式
开发语言·c++·算法
liu****21 分钟前
6.多人协作(同一分支下(不常用))(一)
c++·gitee·版本控制
穿条秋裤到处跑22 分钟前
每日一道leetcode(2026.03.25):等和矩阵分割 I
算法·leetcode·矩阵
齐鲁大虾29 分钟前
VC++ 如何获取打印机的脱机/连接状态
开发语言·c++·获取打印机状态