LeetCode:198. 打家劫舍

简介

题目链接:https://leetcode.cn/problems/house-robber/description/

解决方式:数组 + 动态规划

这是作者学习众多大神的思路进行解题的步骤,很推荐大家解题的时候去看看题解里面大佬们的思路、想法!

推荐看 nettee 大佬的讲解。

动态规划

经典

解题思路:重要的是状态的定义(前 k 个房间最大金额)和状态转移方程式(k - 1 房间偷还是不偷)。

java 复制代码
class Solution {
    public int rob(int[] nums) {
        // 边界处理
        if(nums.length == 0){
            return 0;
        }
        // 状态的定义
        int n = nums.length;
        int[] dp = new int[n + 1];
        // 初始值
        dp[0] = 0;
        dp[1] = nums[0];
        // 状态转移方程式(递推)
        for(int i = 2; i <= n; i++){
            dp[i] = Math.max(dp[i - 1], nums[i - 1] + dp[i - 2]);
        }
        // 返回结果
        return dp[n];
    }
}

空间优化

java 复制代码
public int rob(int[] nums) {
    int prev = 0;
    int curr = 0;

    // 每次循环,计算"偷到当前房子为止的最大金额"
    for (int i : nums) {
        // 循环开始时,curr 表示 dp[k-1],prev 表示 dp[k-2]
        // dp[k] = max{ dp[k-1], dp[k-2] + i }
        int temp = Math.max(curr, prev + i);
        prev = curr;
        curr = temp;
        // 循环结束时,curr 表示 dp[k],prev 表示 dp[k-1]
    }

    return curr;
}
相关推荐
罗湖老棍子2 小时前
打鼹鼠_二维树状数组(信息学奥赛一本通- P1540)(二维树状数组模版题)
数据结构·算法·树状数组·二维树状数组
_日拱一卒2 小时前
LeetCode:盛最多水的容器
数据结构·算法·leetcode
zyhomepage2 小时前
科技的成就(七十二)
开发语言·人工智能·科技·算法·内容运营
计算机安禾2 小时前
【数据结构与算法】第2篇:C语言核心机制回顾(一):指针、数组与结构体
c语言·开发语言·数据结构·c++·算法·链表·visual studio
dapeng28702 小时前
C++代码重构实战
开发语言·c++·算法
xu_wenming2 小时前
为什么要在项目中加入 ESP‑NN(神经网络)
mcu·物联网·算法·iot
LXY_BUAA2 小时前
《嵌入式面试》_1面京东科技-金刚项目组前准备_20260323
面试·职场和发展
juleskk2 小时前
3.22 复试训练
算法
还不秃顶的计科生2 小时前
力扣第84题:完全平方数
算法·leetcode·职场和发展