198. 打家劫舍 - 力扣(LeetCode)

代码

python 复制代码
# encoding = utf-8
# 开发者:Alen
# 开发时间: 14:03 
# "Stay hungry,stay foolish."

class Solution(object):
    def rob(self, nums):
        """
        :type nums: List[int]
        :rtype: int
        """
        rob1, rob2 = 0, 0
        # [rob1, rob2, n, n+1]
        for num in nums:
            temp = max(num + rob1, rob2)
            rob1, rob2 = rob2, temp
        return rob2

迭代过程

python 复制代码
# nums = [2, 7, 9, 3, 1]

num = 2:
temp = max(0 + 2, 0) = 2
rob1 = 0, rob2 = 2

num = 7:
temp = max(0 + 7, 2) = 7
rob1 = 2, rob2 = 7

num = 9:
temp = max(2 + 9, 7) = 11
rob1 = 7, rob2 = 11

num = 3:
temp = max(7 + 3, 11) = 11
rob1 = 11, rob2 = 11

num = 1:
temp = max(11 + 1, 11) = 12
rob1 = 11, rob2 = 12

最终结果

返回 rob2 = 12

最优方案是:抢劫第1个(2)、第3个(9)、第5个(1)个房屋 = 2 + 9 + 1 = 12

为什么这样是有效的?

这个算法的高明之处在于:

  1. 滚动数组思想:只保存前两个状态,空间复杂度O(1)

  2. 最优子结构:每个位置的最优解只依赖于前两个位置的最优解

  3. 决策完备性:在每个位置,我们都考虑了所有可能的决策(抢或不抢)

时间复杂度

  • 时间复杂度:O(n),只需要一次遍历

  • 空间复杂度:O(1),只用了两个变量

结果

解题步骤:https://www.bilibili.com/video/BV1UprvBUEuH/?vd_source=15b4bc8968fa5203cc470cb68ff72c96

相关推荐
总斯霖2 分钟前
HDU 4857 - 逃生 题解
算法
-To be number.wan3 分钟前
算法学习日记 | 模拟
c++·学习·算法
Blossom.1184 分钟前
从“金鱼记忆“到“超级大脑“:2025年AI智能体记忆机制与MoE架构的融合革命
人工智能·python·算法·架构·自动化·whisper·哈希算法
金枪不摆鳍4 分钟前
算法-贪心算法
算法·贪心算法
naruto_lnq4 分钟前
高性能消息队列实现
开发语言·c++·算法
池央6 分钟前
贪心算法-摆动序列
算法·贪心算法
AndrewHZ7 分钟前
【AI黑话日日新】什么是隐式CoT?
人工智能·深度学习·算法·llm·cot·复杂推理
努力学算法的蒟蒻8 分钟前
day74(2.2)——leetcode面试经典150
面试·职场和发展
芒克芒克9 分钟前
LeetCode 跳跃游戏 II 最优解法:贪心算法
leetcode·游戏·贪心算法
User_芊芊君子11 分钟前
【LeetCode原地复写零】:双指针+逆向填充,O(n)时间O(1)空间最优解!
android·linux·leetcode