LeetCode讲解篇之198. 打家劫舍

LeetCode讲解篇之198. 打家劫舍

文章目录

题目描述

题解思路

该问题可以通过递推来完成

递推公式:

前n间房的最大金额 = max(前n-1间房的最大金额, 前n-2间房的最大金额+第n-1间房的最大金额)

题解代码

go 复制代码
func rob(nums []int) int {
    if len(nums) == 0 {
        return 0
    }
    n := len(nums)
    dp := make([]int, n + 1)
    dp[0] = 0
    dp[1] = nums[0]
    for k := 2; k <= n; k++ {
        if dp[k-1] > dp[k-2] + nums[k-1] {
            dp[k] = dp[k-1]
        } else {
            dp[k] = dp[k-2] + nums[k-1]
        }
    }

    return dp[n]
}
相关推荐
tankeven3 分钟前
HJ132 小红走网格
c++·算法
小璐资源网7 分钟前
算法黑箱的可解释性危机
算法
不想看见40412 分钟前
Power of Four二进制特性--力扣101算法题解笔记
数据结构·算法
做怪小疯子27 分钟前
Leetcode刷题——8.重叠区间
算法·leetcode·职场和发展
2401_8578652329 分钟前
C++模块接口设计
开发语言·c++·算法
add45a40 分钟前
嵌入式C++低功耗设计
开发语言·c++·算法
DeepModel42 分钟前
【概率分布】指数分布(Exponential Distribution)原理、推导与实战
python·算法·概率论
_饭团1 小时前
指针核心知识:5篇系统梳理3
c语言·数据结构·算法·leetcode·面试·学习方法·改行学it
2401_874732531 小时前
C++中的状态模式
开发语言·c++·算法
BB学长1 小时前
LBM vs FVM:谁才是 CFD 的未来?
人工智能·算法·机器学习