89. 打家劫舍【动态规划】

题目

题解

python 复制代码
class Solution:
    def rob(self, nums: List[int]) -> int:
        N = len(nums)
        # 定义状态: dp[i]表示从第i间房子开始抢劫,最多能抢到的金额
        dp = [0 for i in range(N)]

        for i in range(N-1, -1, -1):
            if i == N-1:
                dp[i] = nums[i]
            elif i == N-2:
                dp[i] = max(nums[i], nums[i+1])
            else:
                dp[i] = max(dp[i+1], nums[i] + dp[i+2])

        return dp[0]
相关推荐
big_rabbit050210 分钟前
[算法][力扣101]对称二叉树
数据结构·算法·leetcode
美好的事情能不能发生在我身上30 分钟前
Hot100中的:贪心专题
java·数据结构·算法
2301_821700531 小时前
C++编译期多态实现
开发语言·c++·算法
xixihaha13241 小时前
C++与FPGA协同设计
开发语言·c++·算法
小小怪7502 小时前
C++中的函数式编程
开发语言·c++·算法
xixixiLucky2 小时前
编程入门算法题---小明爬楼梯求爬n层台阶一共多少种方法
算法
剑锋所指,所向披靡!2 小时前
数据结构之线性表
数据结构·算法
m0_672703314 小时前
上机练习第49天
数据结构·算法
样例过了就是过了4 小时前
LeetCode热题100 N 皇后
数据结构·c++·算法·leetcode·dfs·深度优先遍历
霖大侠4 小时前
CPAL: Cross-Prompting Adapter With LoRAs forRGB+X Semantic Segmentation
人工智能·深度学习·算法·机器学习·transformer