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];
    }
相关推荐
tanyongxi6628 分钟前
C++ 继承详解:基础篇(含代码示例)
开发语言·c++
远瞻。1 小时前
【论文精读】2023 AAAI--FastRealVSR现实世界视频超分辨率(RealWorld VSR)
论文阅读·算法·超分辨率重建
C++chaofan2 小时前
P2089 烤鸡
数据结构·c++·算法
橙子小哥的代码世界2 小时前
面向超大规模模型的提示词工程
深度学习·算法·大模型·提示词工程
ergevv2 小时前
std::thread的说明与示例
c++·thread
龙湾开发2 小时前
C++ vscode配置c++开发环境
开发语言·c++·笔记·vscode·学习
远瞻。2 小时前
【论文精读】2023 CVPRW--EAVSR现实世界视频超分辨率(RealWorld VSR)
论文阅读·算法·超分辨率重建
爱学习的小邓同学2 小时前
C++ --- string
c++·笔记
大坏波3 小时前
C/C++内存管理
java·c语言·c++
图初3 小时前
路径规划算法BFS/Astar/HybridAstar简单实现
算法·动态规划·astar·宽度优先·hybridastar