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]
}
相关推荐
仰泳的熊猫8 分钟前
题目2281:蓝桥杯2018年第九届真题-次数差
数据结构·c++·算法·蓝桥杯
blackicexs13 分钟前
第九周第一天
数据结构·算法
小小怪75019 分钟前
C++中的代理模式高级应用
开发语言·c++·算法
Dfreedom.26 分钟前
归一化技术全景指南
深度学习·算法·机器学习·归一化
Genevieve_xiao26 分钟前
【写给新人】在 vscode 中配置适用于算法竞赛背景的 c/c++
c语言·vscode·算法
TracyCoder12333 分钟前
LeetCode Hot100(70/100)—— 322. 零钱兑换
算法·leetcode·职场和发展
2401_8914821736 分钟前
C++中的观察者模式
开发语言·c++·算法
沐雲小哥38 分钟前
bevfomer算法嵌入的tricks
数码相机·算法
wangzy198239 分钟前
一个高效稳定的多边形三角化算法(支持自交和孤岛检测)
算法·图形渲染
保持低旋律节奏40 分钟前
第三讲一元函数微分学的概念
算法