力扣HOT100(49)动态规划 -- 打家劫舍

先从最简单的情况入手,找规律

我们从只有 1 间房、2 间房、3 间房的情况开始,一步步推导:

  1. 只有 1 间房 [a] :没得选,只能偷这间,最多偷 a
  2. 有 2 间房 [a, b] :不能同时偷,选钱多的那间,最多偷 max(a, b)
  3. 有 3 间房 [a, b, c]
    • 选项 1:偷第 3 间房 → 不能偷第 2 间 → 最多偷 a + c
    • 选项 2:不偷第 3 间房 → 最多偷前 2 间的最大值 max(a, b)
    • 所以最多偷 max(a + c, max(a, b))

发现规律了吗? 对于第 k 间房,你只有两个选择:偷 或者 不偷,取两个选择中钱更多的那个

动态规划核心思路(一句话讲透)

dp[i] 表示前 i 间房能偷到的最高金额,那么:

  • 如果偷第 i 间房:第 i-1 间房不能偷 → 总金额 = dp[i-2] + nums[i]
  • 如果不偷第 i 间房:总金额 = dp[i-1](前 i-1 间房的最高金额)

所以状态转移方程:

复制代码
dp[i] = max(dp[i-2] + nums[i], dp[i-1])

1. 处理边界情况

  • 如果数组为空(没有房屋):返回 0
  • 如果数组只有 1 个元素(只有 1 间房):返回这个元素的值

2. 初始化 dp 数组

  • dp[0] = nums[0]:只有第 0 间房,最多偷 nums 0
  • dp[1] = max(nums[0], nums[1]):有两间房,偷钱多的那间

3. 遍历数组,计算 dp 数组

从第 2 间房开始(i=2),一直到最后一间房(i=n-1):

  • 按照状态转移方程 dp[i] = max(dp[i-2] + nums[i], dp[i-1]) 计算每一个 dp i

4. 返回结果

dp[n-1] 就是前 n 间房能偷到的最高金额

cpp 复制代码
class Solution {
public:
    int rob(vector<int>& nums) {
        //如果没有房 返回0
        if(nums.empty()){
            return 0;
        }

        //有一个房
        int num = nums.size();
        if(num == 1){
            return nums[0];
        }

        //数组
        vector<int> dp(num);
        dp[0] = nums[0];
        dp[1] = max(nums[0],nums[1]);

        for(int i = 2;i<num;i++){
            
            dp[i] =max(dp[i-2] + nums[i],dp[i-1]);
        }

        return dp[num-1];
        
    }
};
相关推荐
kisshyshy1 天前
🍦 雪糕、食堂、火车厢:三幅漫画吃透栈、队列与链表
javascript·算法
猿人谷1 天前
不只是 CPU 阈值:STAR 如何用 GAT + Transformer 做容器级自动扩缩容?
人工智能·算法
复杂网络1 天前
Stable Diffusion 视觉大模型微调技术深度调研
算法
复杂网络1 天前
基于 Stable Diffusion 架构的视觉大模型代表性工作与原理深度解析
算法
MrZhao4001 天前
Agent Loop 如何用 Hook 扩展:权限、日志与工具拦截
算法
MrZhao4001 天前
Agent 为什么需要 Skills:别把所有知识都塞进 system prompt
算法
JieE2123 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2124 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack204 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树4 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色