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

相关推荐
你撅嘴真丑4 小时前
第九章-数字三角形
算法
uesowys5 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
ValhallaCoder5 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮5 小时前
AI 视觉连载1:像素
算法
智驱力人工智能5 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥6 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风6 小时前
代码随想录第十五天
数据结构·算法·leetcode
XX風6 小时前
8.1 PFH&&FPFH
图像处理·算法
NEXT067 小时前
前端算法:从 O(n²) 到 O(n),列表转树的极致优化
前端·数据结构·算法
代码游侠7 小时前
学习笔记——设备树基础
linux·运维·开发语言·单片机·算法