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

相关推荐
南境十里·墨染春水3 小时前
C++ 工厂模式:从入门到进阶,彻底掌握对象创建的艺术
开发语言·c++·算法
@insist1234 小时前
系统架构设计师-实时性评价、调度算法与内核架构选型
算法·架构·系统架构·软考·系统架构设计师·软件水平考试
一只齐刘海的猫9 小时前
【Leetcode】找到字符串中所有字母异位词
算法·leetcode·职场和发展
海清河晏1119 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
IronMurphy11 小时前
【算法五十七】146. LRU 缓存
算法·缓存
文艺倾年11 小时前
【强化学习】强化学习基本概念,20W字总结(一)
人工智能·python·语言模型·自然语言处理·面试·职场和发展·大模型
凌波粒11 小时前
LeetCode--108.将有序数组转换为二叉搜索树(二叉树)
算法·leetcode·职场和发展
liulilittle11 小时前
KCC:在 BBR 思路上的一次探索
网络·tcp/ip·算法·bbr·通信·拥塞控制·kcc
浦信仿真大讲堂11 小时前
达索系统SIMULIA Abaqus 2026接触和约束的增强新功能介绍
人工智能·python·算法·仿真软件·达索软件