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];
    }
相关推荐
中國龍在廣州12 小时前
现在人工智能的研究路径可能走反了
人工智能·算法·搜索引擎·chatgpt·机器人
快手技术12 小时前
NeurIPS 2025 | 可灵团队提出 Flow-GRPO, 首次将在线强化学习引入流匹配生成模型
算法
星释12 小时前
Rust 练习册 67:自定义集合与数据结构实现
数据结构·算法·rust
6***x54512 小时前
C++在计算机视觉中的图像处理
c++·图像处理·计算机视觉·游戏引擎·logback·milvus
fpcc12 小时前
跟我学C++中级篇——内存访问违例
c++
E***q53913 小时前
C++内存对齐优化
开发语言·c++
D_evil__13 小时前
[C++高频精进] 文件IO:文件操作
c++
前端小L14 小时前
图论专题(十九):DAG上的“关键路径”——极限规划「并行课程 III」
算法·矩阵·深度优先·图论·宽度优先
scx2013100414 小时前
20251116 树状DP总结
算法·深度优先·图论
Aspect of twilight14 小时前
LeetCode华为大模型岗刷题
python·leetcode·华为·力扣·算法题