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]
}
相关推荐
你怎么知道我是队长2 小时前
C语言---排序算法4---希尔排序法
c语言·算法·排序算法
iAkuya2 小时前
(leetcode)力扣100 54实现Trie树
算法·leetcode·c#
TracyCoder1232 小时前
LeetCode Hot100(20/100)——19. 删除链表的倒数第 N 个结点
算法·leetcode
hrrrrb2 小时前
【算法设计与分析】随机化算法
人工智能·python·算法
进击的小头2 小时前
一阶IIR低通滤波器:从原理到嵌入式实战
c语言·算法
2301_811232983 小时前
C++中的契约编程
开发语言·c++·算法
2401_829004023 小时前
C++中的访问者模式
开发语言·c++·算法
青槿吖3 小时前
第二篇:JDBC进阶骚操作:防注入、事务回滚、连接池优化,一篇封神
java·开发语言·jvm·算法·自动化
sin_hielo3 小时前
leetcode 1984
数据结构·算法·leetcode