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;
}
相关推荐
手写码匠18 分钟前
从零实现 Prompt 工程引擎:结构化提示、自动优化与多轮自省体系
人工智能·深度学习·算法·aigc
无限码力42 分钟前
阿里算法岗 0530笔试真题 - 多约束条件下的元素匹配统计
算法·阿里笔试真题·阿里机试真题·阿里算法岗笔试
lqqjuly1 小时前
MLA — 多头潜在注意力深度解析
深度学习·神经网络·算法
吴可可1231 小时前
SolidWorks草图转三维DWG技巧
算法
redaijufeng2 小时前
C++雾中风景7:闭包
c++·算法·风景
小欣加油2 小时前
leetcode287寻找重复数
数据结构·c++·算法·leetcode
尽兴-3 小时前
2.1 向量基础:Embedding、余弦相似度、欧氏距离、向量检索
算法·embedding·欧氏距离·向量检索·余弦相似度
Black蜡笔小新3 小时前
自动化AI算法训练服务器DLTM训推一体工作站赋能多行业智能化升级
人工智能·算法·自动化
怪兽学LLM3 小时前
LeetCode 438 找到字符串中所有字母异位词(Python 固定滑动窗口+字符计数解法)
python·算法·leetcode