当前位置: 首页 > news >正文

LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅

LeetCode 337:打家劫舍 III(House Robber III)—— 题解 ✅

📖 内容概要

在上次打家劫舍的基础上,小偷发现了一个新的可行区域:
二叉树结构的房屋
如果直接相连的节点(父节点和子节点)在同一晚被闯入,系统会自动报警。

求在不触动警报的前提下,一夜之间能够偷窃到的最高金额

✅ 树形 DP
✅ 后序遍历(自底向上)
✅ 打家劫舍系列第三题


💡 解题思路(核心)

一、关键难点

  • 房屋不再是线性或环形
  • 而是二叉树结构
  • 父子节点不能同时偷

二、状态定义(非常关键)

对于以root为根的树,返回两个值:

res[0] = 不偷 root 时,子树的最大金额 res[1] = 偷 root 时,子树的最大金额

三、状态转移(树形 DP)

✅ 偷当前节点
val2=root.val+left[0]+right[0];
  • 必须不能偷左右子节点

✅ 不偷当前节点
val1=max(left[0],left[1])+max(right[0],right[1]);
  • 左右子树自由选择最优方案

四、递归 + 后序遍历

先计算左子树 再计算右子树 最后合并当前节点

✅ 自底向上
✅ 无重复计算


✅ AC 代码(Java)

/** * Definition for a binary tree node. */classTreeNode{intval;TreeNodeleft;TreeNoderight;TreeNode(){}TreeNode(intval){this.val=val;}TreeNode(intval,TreeNodeleft,TreeNoderight){this.val=val;this.left=left;this.right=right;}}classSolution{publicintrob(TreeNoderoot){int[]res=help(root);returnMath.max(res[0],res[1]);}// 返回 [不偷当前节点的最大值, 偷当前节点的最大值]publicint[]help(TreeNoderoot){if(root==null){returnnewint[]{0,0};}int[]left=help(root.left);int[]right=help(root.right);// 不偷当前节点intval1=Math.max(left[0],left[1])+Math.max(right[0],right[1]);// 偷当前节点intval2=root.val+left[0]+right[0];returnnewint[]{val1,val2};}}

⏱️ 复杂度分析

指标复杂度
时间复杂度O(n)(每个节点只访问一次)
空间复杂度O(h)(递归栈,h 为树高)

🔍 打家劫舍三部曲对比

题目结构解法
198线性街道一维 DP
213环形拆环为链
337二叉树树形 DP

✅ 一句话总结

树形 DP = 后序遍历 + 每个节点返回“偷 / 不偷”两种状态的最大值。


📌 面试加分点(建议记住)

  • ✅ 为什么返回数组而不是单个值?
  • ✅ 为什么是后序遍历?
  • ✅ 如何把树形 DP 抽象成状态机?
  • ✅ 与记忆化搜索的关系
http://www.jsqmd.com/news/964298/

相关文章:

  • 解锁华硕笔记本隐藏潜能:G-Helper轻量控制工具深度体验指南
  • 别再傻傻分不清!一张图看懂SATA、M.2、NVMe硬盘怎么选(附避坑指南)
  • Python基础:字符串索引与切片操作完全指南
  • 模板驱动型文档自动化:结构化内容复用与三层架构解析
  • 政府购买服务目录中信息化项目分类与政府采购服务相关问题研究报告
  • 模拟灰度传感器原理与实战:从循迹小车到简易颜色识别
  • AD6.9授权冲突解决:局域网多机唯一序列号配置指南
  • LED路灯技术解析:从光效、散热到智能控制,全面对比高压钠灯
  • CSDN创作者必看:AI营销卡片关闭权限已灰度开放!仅限开通「专业认证」且近30天原创率>85%的账号(附自查清单)
  • 车联网多车协同通信调度代码集:含MADDPG与MADQN完整实现及仿真环境
  • 昇腾CANN集群通信库hcomm:多机分布式训练的NCCL兼容通信方案
  • Kubernetes 中 4 种容器设计模式
  • 苏州天脉:从手机散热到AI新领域,330倍估值能否靠苹果与新业务支撑?
  • 【限时可复刻】CSDN AI+内容裂变+线索评分三步法:让咨询量暴涨210%的招生闭环(附配置参数表)
  • 从开发到部署:在快马平台上构建一个可投入实战的完整winhance应用
  • RTX5消息队列创建踩坑实录:从osMessageQueueNew参数配置到Keil调试视图全解析
  • 2026年拉杆铝箱/抽屉式航空箱/储能便携拉杆箱厂家推荐:多功能与防震防护实力品牌精选 - 品牌企业推荐师(官方)
  • 从兼职工程师到行业认知:电源设计、3C认证与MCU选型的实战教训
  • 【CSDN AI数字营销实战指南】:开通后创作次数是否真有限制?3大隐藏规则99%用户不知道
  • 2026天河区搬家公司全解析|高端定制、日式精搬、正规品牌避坑指南 - gzdjxd
  • 从零构建51单片机最小系统:原理、设计与调试全攻略
  • CSDN官方未公开的行业效能热力图:17个细分领域CTR、CPL、LTV/CAC三维对比,仅剩最后237份内部测试权限可申领
  • 新手福音:在快马平台零代码基础体验claude code的AI编程助手魅力
  • 华科毕设实战资源:RGAT+GRU融合模型跑通Cadets与StreamSpot溯源图APT检测全流程
  • VidDown:免费视频解析下载 + 开发工具箱
  • 如何用AutoSubs实现3倍速本地AI字幕生成?终极免费指南
  • 厦门做招牌多少钱
  • 从GAN到GE-GAN:我是如何用‘造假’数据提升智能交通系统精度的 | 实战经验分享
  • 2026年6月长沙创业财税避坑指南!长沙注册公司/代理记账/记账报税机构甄选测评 - 资讯速览
  • 冷门技术内容冷启动难?用CSDN AI做选题挖掘,3步锁定高转化低竞争蓝海选题,错过再等半年!