【 每天学习一点算法 2026/01/04】打家劫舍

每天学习一点算法 2026/01/04

题目:打家劫舍

你是一个专业的小偷,计划偷窃沿街的房屋。每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警。

给定一个代表每个房屋存放金额的非负整数数组,计算你 不触动警报装置的情况下 ,一夜之内能够偷窃到的最高金额。

新年新开始,坚持学习算法。

又是一道动态规划的问题,我们来分析一下,我们入按照数组顺序的挨个计算在每个房间的能偷窃到的最高金额会有哪些情况呢?很明显,每个房间就只存在两种情况(偷/不偷),那我们来逐个房间分析,并将每个偷与不偷能窃到的最大金额用一个二维数组存储起来。

  • 第一个房间:两种可能 0 或者 nums[0]arr[0] = [0, nums[0]]

  • 第二个房间:两种可能

    1. 如果这个房间不偷那就是截至上一个房间偷到的最高金额(因为这是第二房间所以一定是nums[0]
    2. 如果这个房间偷,那肯定是上一个房间未偷盗情况下的金额 + 这个房间的金额

    arr[1] = [nums[0], arr[0][0] + nums[1]]

  • 第 n 个房间:根据第二房间的分析我们可以知道,如果这个房间为偷取,我们应该拿到上一个能够偷窃到的最高金额(Math.max(arr[n - 1][0], arr[n - 1][1])),所以 arr[n] = [Math.max(arr[n - 1][0], arr[n - 1][1]), arr[n - 1][0] + nums[n]]

这样我们就成功找到了房间能够偷窃到的最高金额的规律

typescript 复制代码
function rob(nums: number[]): number {
  if (nums.length === 1) return nums[0] // 如果只有一个房间直接返回
  let arr = [[0, nums[0]]] // 二维数组存储房间最高金额情况 [未盗窃, 已盗窃][]
  // 循环计算每个房间的情况
  for (let i = 1; i < nums.length; i++) {
    arr.push([Math.max(arr[i - 1][0], arr[i - 1][1]), arr[i - 1][0] + nums[i]])
  }
  // 返回最后一个房间的最大金额
  const last = arr.pop()
  return Math.max(last[0], last[1])
};

我们可以看到每次循环都只用到了前一个房间的数据,所以我们可以考虑不用数组而是用两个变量来存储上一个房间的值。

typescript 复制代码
function rob(nums: number[]): number {
  if (nums.length === 1) return nums[0] // 如果只有一个房间直接返回
  let preMax = nums[0] // 存储上一个房间能够偷窃到的最高金额
  let preNo = 0 // 存储未偷盗情况下的最高金额
  // 循环计算每个房间的情况
  for (let i = 1; i < nums.length; i++) {
    const preDo = preNo + nums[i] // 当前房间已偷盗
    preNo = preMax // 当前房间未偷盗为上一个房间的最大值
    preMax = Math.max(preNo, preDo) // 当前房间最大值为 当前房间未偷盗和已偷盗的最大值
  }
  // 返回最后一个房间的最大金额
  return preMax
};

题目来源:力扣(LeetCode)

相关推荐
仰泳的熊猫1 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
无极低码4 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发5 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
superior tigre5 小时前
22 括号生成
算法·深度优先
盐水冰6 小时前
【烘焙坊项目】后端搭建(12) - 订单状态定时处理,来单提醒和顾客催单
java·后端·学习
Hello小赵6 小时前
视频压缩编码学习(一)—— 基础知识大集合
学习
努力也学不会java6 小时前
【缓存算法】一篇文章带你彻底搞懂面试高频题LRU/LFU
java·数据结构·人工智能·算法·缓存·面试
旖-旎7 小时前
二分查找(x的平方根)(4)
c++·算法·二分查找·力扣·双指针
ECT-OS-JiuHuaShan7 小时前
朱梁万有递归元定理,重构《易经》
算法·重构