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];
    }
相关推荐
didiplus8 分钟前
【趣学Python算法100例】三色球
开发语言·python·算法
管家罢了9 分钟前
list的模拟实现
开发语言·c++
木向14 分钟前
leetcode_238:除自身以外数组的乘积
数据结构·算法·leetcode
一只小松许️17 分钟前
C++常引用详解
开发语言·c++
ubuntu180420 分钟前
C0013.Clion中利用C++调用opencv打开摄像头
开发语言·c++·opencv
vir0237 分钟前
Excel 表列名称(26进制)
开发语言·算法·leetcode
前端 贾公子38 分钟前
Node.js 中使用 bcrypt 对密码进行哈希处理
算法·node.js·哈希算法
倔强的石头1061 小时前
【C语言指南】数据类型详解(上)——内置类型
c语言·开发语言·算法
陈琦煜1 小时前
E. Tree Pruning Codeforces Round 975 (Div. 2)
算法·机器学习·剪枝
kuan_li_lyg1 小时前
树莓派 AI 摄像头(Raspberry Pi AI Camera)教程
人工智能·stm32·单片机·算法·计算机视觉·机器人·ros