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 分钟前
AI Agent 的道与术
人工智能·职场和发展·agi
纽扣6679 分钟前
【算法进阶之路】链表核心:快慢指针与反转链表专题精讲
数据结构·c++·算法·链表
浅念-20 分钟前
吃透栈:LeetCode 栈算法题全解析
数据结构·c++·算法·leetcode·职场和发展·
吟安安安安21 分钟前
【算法设计与分析】第一讲 算法基础(上)
算法
阿Y加油吧21 分钟前
二刷 LeetCode:62. 不同路径 & 64. 最小路径和 复盘笔记
笔记·算法·leetcode
生成论实验室26 分钟前
《源·觉·知·行·事·物:生成论视域下的统一认知语法》导论:在破碎的世界寻找统一语法
人工智能·科技·算法·架构·创业创新
承渊政道27 分钟前
【动态规划算法】(两个数组的DP问题深度剖析与求解方法)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
杨连江31 分钟前
原子级平面限域协同晶核诱导定向生长单层鳞片石墨的研究
算法
MATLAB代码顾问37 分钟前
混合粒子群-模拟退火算法(HPSO-SA)求解作业车间调度问题——附MATLAB代码
算法·matlab·模拟退火算法
Felven41 分钟前
C. Prefix Min and Suffix Max
算法