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;
}
相关推荐
FluxMelodySun7 小时前
机器学习(三十一) 半监督SVM与图半监督学习
人工智能·算法·机器学习
zjeweler7 小时前
网安护网面试-3-鸿鹄科技护网面试
科技·网络安全·面试·职场和发展·护网行动
磊 子7 小时前
八大排序之插入排序+希尔排序
数据结构·算法·排序算法
kishu_iOS&AI7 小时前
机器学习 —— 逻辑回归(混淆矩阵)
人工智能·算法·机器学习·逻辑回归
W23035765737 小时前
经典算法:打家劫舍(动态规划 + 回溯求最优解)C++ 超详细解析
c++·算法·动态规划
Dev7z7 小时前
基于改进小波阈值的sEMG信号降噪与手势识别系统设计与实现
算法·手势识别·改进小波阈值·semg·信号降噪
灵感__idea14 小时前
Hello 算法:贪心的世界
前端·javascript·算法
ZK_H16 小时前
嵌入式c语言——关键字其6
c语言·开发语言·计算机网络·面试·职场和发展
澈20716 小时前
深入浅出C++滑动窗口算法:原理、实现与实战应用详解
数据结构·c++·算法
ambition2024216 小时前
从暴力搜索到理论最优:一道任务调度问题的完整算法演进历程
c语言·数据结构·c++·算法·贪心算法·深度优先