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;
}
相关推荐
科研前沿44 分钟前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算
水蓝烟雨1 小时前
1931. 用三种不同颜色为网格涂色
算法·leetcode
晨曦夜月1 小时前
map与unordered_map区别
算法·哈希算法
Morwit1 小时前
QML组件之间的通信方案(暴露子组件)
c++·qt·职场和发展
图码2 小时前
如何用多种方法判断字符串是否为回文?
开发语言·数据结构·c++·算法·阿里云·线性回归·数字雕刻
handler012 小时前
Linux 内核剖析:进程优先级、上下文切换与 O(1) 调度算法
linux·运维·c语言·开发语言·c++·笔记·算法
minglie12 小时前
实数列的常用递推模式
算法
代码小书生2 小时前
math,一个基础的 Python 库!
人工智能·python·算法
AI科技星2 小时前
全域数学·数术本源·高维代数卷(72分册)【乖乖数学】
人工智能·算法·数学建模·数据挖掘·量子计算
生成论实验室2 小时前
《事件关系阴阳博弈动力学:识势应势之道》第一篇:生成正在发生——从《即事经》到事件-关系网络
人工智能·科技·算法·架构·创业创新