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]
}
相关推荐
王老师青少年编程31 分钟前
2025年12月GESP(C++二级): 环保能量球
c++·算法·gesp·csp·信奥赛·二级·环保能量球
weixin_4334176737 分钟前
Canny边缘检测算法原理与实现
python·opencv·算法
CoderCodingNo43 分钟前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法
youngee111 小时前
hot100-61电话号码的字母组合
java·数据结构·leetcode
POLITE31 小时前
Leetcode 76.最小覆盖子串 JavaScript (Day 6)
javascript·算法·leetcode
张老师Plus2 小时前
依依东望,望的是时间
经验分享·程序人生·面试·职场和发展·跳槽
一条大祥脚2 小时前
26.1.1
数据结构·算法
csuzhucong2 小时前
圆柱三阶魔方、六棱柱魔方
算法
mit6.8242 小时前
vector<int> dfs
算法