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

递归封神!二叉树两大究极考题:路径总和 III + 最近公共祖先|面试原地 AC

目录前言一、路径总和 III任意起点、任意终点的路径计数思路一句话总结完整 AC 代码关键点小白精讲二、二叉树的最近公共祖先后序遍历的神级应用思路一句话总结完整 AC 代码小白秒懂逻辑三、两道题核心思想总结路径总和 III最近公共祖先前言二叉树最能拉开差距的就是递归思想。今天这两道题一道是任意路径求和高频易错一道是最近公共祖先递归模板题。它们不考复杂数据结构只考你对递归、回溯、后序遍历的理解。全文思路直白、代码干净适合直接收藏背模板。一、路径总和 III任意起点、任意终点的路径计数这道题最大特点路径不需要从根开始也不需要在叶子结束只要从上到下即可。很多人卡在用 int 溢出、递归边界不清我直接给你能 AC、防溢出、最稳写法。思路一句话总结以每一个节点作为起点向下递归寻找路径和为 targetSum 的条数。两层递归1遍历树中每个节点充当起点2从该节点向下 DFS累加统计满足条件的路径关键点必须用 long 避免数值溢出完整 AC 代码java运行/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode() {} * TreeNode(int val) { this.val val; } * TreeNode(int val, TreeNode left, TreeNode right) { * this.val val; * this.left left; * this.right right; * } * } */ class Solution { /** * 深度优先以每个节点为起点向下寻找满足条件的路径 * 最终总和 当前节点贡献 左子树贡献 右子树贡献 */ public int pathSum(TreeNode root, int targetSum) { if (root null) return 0; // 当前节点作为起点的路径数 int res rootSum(root, (long) targetSum); // 递归处理左右子树 res pathSum(root.left, targetSum); res pathSum(root.right, targetSum); return res; } /** * 从 node 出发向下寻找和为 targetSum 的路径条数 * 使用 long 防止 int 溢出 */ public int rootSum(TreeNode node, long targetSum) { int res 0; if (node null) return 0; long val node.val; // 当前节点值正好匹配找到一条路径 if (val targetSum) { res; } // 继续向左右子树寻找目标和减去当前值 res rootSum(node.left, targetSum - val); res rootSum(node.right, targetSum - val); return res; } }关键点小白精讲为什么用 long测试用例会给极大数int 相加会溢出变负数导致错误判断。两层递归结构清晰一层遍历所有起点一层向下延伸路径。边界干净空节点直接返回 0不做多余判断。二、二叉树的最近公共祖先后序遍历的神级应用这道题是面试必考模板代码短到离谱但思想极经典。核心就是后序遍历 左右结果判断祖先位置。思路一句话总结采用后序遍历先左、再右、最后处理根。如果当前节点是 p 或 q直接返回它。如果左右子树都返回非空说明 p、q 分别在两侧当前节点就是祖先。如果一侧非空一侧空说明目标都在非空那一侧返回那一侧即可。完整 AC 代码java运行/** * Definition for a binary tree node. * public class TreeNode { * int val; * TreeNode left; * TreeNode right; * TreeNode(int x) { val x; } * } */ class Solution { /** * 后序递归从下往上找最近公共祖先 */ public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) { // 递归出口空节点 或 找到 p/q直接返回 if (root null || root p || root q) { return root; } // 左子树查找 TreeNode left lowestCommonAncestor(root.left, p, q); // 右子树查找 TreeNode right lowestCommonAncestor(root.right, p, q); // 左右都找到了 → 当前节点就是最近公共祖先 if (left ! null right ! null) { return root; } // 哪边不为空祖先就在哪边 return left ! null ? left : right; } }小白秒懂逻辑这就是从下往上 “冒泡” 结果。只要左右各找到一个当前节点就是它们的交汇点。代码极简、无冗余、面试直接默写。三、两道题核心思想总结路径总和 III题型双重递归、路径搜索关键词任意起点、向下延伸、long 防溢出口诀每个节点当起点递归向下凑总和最近公共祖先题型后序遍历、递归回溯关键词左右判断、最近公共节点口诀后序左右找两边都有就是祖先

相关文章:

递归封神!二叉树两大究极考题:路径总和 III + 最近公共祖先|面试原地 AC

目录 前言 一、路径总和 III:任意起点、任意终点的路径计数 思路一句话总结 完整 AC 代码 关键点小白精讲 二、二叉树的最近公共祖先:后序遍历的神级应用 思路一句话总结 完整 AC 代码 小白秒懂逻辑 三、两道题核心思想总结 路径总和 III 最近…...

损失2万块买来的教训:出海独立站如何从“裸奔”走向云原生高可用架构?

上个月,我帮一位做跨境宠物用品的老板做了一次紧急的架构救火。起因是他发现网站在正常投放 Google Ads 的情况下,突然大面积访问超时。我介入排查后发现,服务器 CPU 已经飙升到 100%,Nginx 日志里密密麻麻全是针对 /api/checkout…...

.shop 域名 SEO 优化有什么技巧

.shop 域名 SEO 优化有什么技巧 在当今互联网时代,域名不仅仅是一个网站的地址,更是品牌的重要组成部分。特别是随着电子商务的蓬勃发展,.shop 域名逐渐成为电商网站的首选。但是,仅有一个好的.shop 域名并不足以让你在搜索引擎上…...

NCP1654 引脚6(FB):外围电阻、电压范围、计算与测试方法

NCP1654 引脚6(FB):外围电阻、电压范围、计算与测试方法 引脚6(FB)是NCP1654的输出电压反馈/关断控制脚,核心功能是采样PFC输出母线电压,送入内部误差放大器,稳定输出电压&#xff1…...

CSS如何为提示框设置特定颜色标识_使用语义化的自定义属性

安装Npgsql包需区分用途:纯ADO.NET用Npgsql,EF Core用Npgsql.EntityFrameworkCore.PostgreSQL;连接字符串须含Password和Timeout;参数用:name非name;异步操作必须await;连接池需合理配置。安装 Npgsql 包时…...

SEO_2024年SEO最新趋势与实战操作解析

2024年SEO最新趋势解析:如何在百度上取得高排名 随着互联网的迅速发展,2024年的SEO(搜索引擎优化)又迎来了新的变化和挑战。在百度这个最大的中文搜索引擎中,如何提升网站的排名成为每一个网站运营者的共同目标。本文…...

mmdetection, mmclassification, mmsegmentation, mmdetection3d, mmselfsup,mmrazor, openmmlab系列答疑,私有数据集

mmdetection, mmclassification, mmsegmentation, mmdetection3d, mmselfsup,mmrazor, openmmlab系列答疑,私有数据集适配,私有模型适配,分布式训练等 欢迎带问题咨询#辅导作业神器 #助力学习好物...

【UVM】UVM类型转换方法详解与代码示例--$cast/静态转换/虚方法/Factory覆盖/类型识别+转换/Callback机制

UVM类型转换方法详解与代码示例 一、六种类型转换方法的代码示例 1. $cast方法(运行时检查) // 基类和子类定义 class Base extends uvm_object;virtual function void display();`uvm_info("BASE", "Base class display", UVM_LOW);endfunction endc…...

考虑一次调频与二次调频及机组差异化特性的风光水火储双目标动态调度研究(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…...

西门子三菱 PLC 编程教程合集|零基础到进阶学习资料整理

在工业自动化领域,PLC 编程是核心技能之一,想要系统掌握西门子、三菱两大品牌的 PLC 编程知识,合适的学习资料能让学习效率事半功倍。本次整理了一批涵盖不同学习阶段的 PLC 编程资料,从零基础入门到针对性机型实操,覆…...

Unity3D实战:从零构建竖屏飞机大战游戏

1. 竖屏游戏的基础设置 第一次打开Unity时,默认是横屏模式。我们需要做的第一件事就是把游戏改成竖屏。这个操作看似简单,但很多新手容易忽略几个关键点。在Game窗口右上角找到分辨率设置,点击加号新建一个预设。这里要特别注意选择"Asp…...

macOS极简安装OpenClaw:gemma-3-12b-it镜像10分钟体验

macOS极简安装OpenClaw:gemma-3-12b-it镜像10分钟体验 1. 为什么选择OpenClawGemma组合 上周我在测试自动化工作流时,偶然发现OpenClaw这个开源框架。它最吸引我的是能直接在本地电脑上实现"AI操控电脑"——就像有个数字员工帮你点击鼠标、整…...

嵌入式开发从入门到精通:C语言、RTOS与Linux实战

1. 嵌入式学习之路:从入门到进阶的完整指南作为一名在嵌入式领域摸爬滚打多年的工程师,我深知这个领域的学习曲线有多陡峭。从最初的51单片机到如今的Linux系统开发,嵌入式技术涵盖了硬件设计、底层驱动、操作系统、网络通信等多个维度。今天…...

树莓派实战指南:从零搭建DHT11温湿度监测系统

1. 认识你的硬件伙伴:DHT11与树莓派 第一次拿到DHT11温湿度传感器时,我盯着这个比指甲盖还小的模块看了半天——就这么个小东西能测量环境数据?后来实测发现它虽然精度不如实验室设备,但家用完全够用。DHT11通过单总线协议通信&am…...

CAN总线分析仪实战:从安装配置到数据收发调试全解析

1. CAN总线分析仪入门指南 第一次接触CAN总线分析仪的朋友可能会觉得这东西有点神秘,其实它就是个帮我们和汽车电子设备"对话"的翻译官。我刚开始用的时候也是一头雾水,后来发现只要掌握几个关键步骤,就能轻松上手。现在市面上常见…...

CAN总线测试与示波器选型实战指南

1. CAN总线测试基础与示波器选型在汽车电子和工业控制领域,CAN总线测试是每个工程师必须掌握的硬核技能。我从事车载诊断系统开发八年,实测过上百个CAN节点,深刻体会到正确使用示波器进行信号测试的重要性。与常见的逻辑分析仪不同&#xff0…...

ESP8266对接GLPi的轻量级IoT工单库

1. 项目概述 glpi_esp8266 是一款专为 ESP8266 系列 Wi-Fi 微控制器设计的轻量级 C 库,其核心使命是构建物联网终端设备与企业级 IT 服务管理(ITSM)平台 GLPi 之间的标准化通信桥梁。该库并非直接对接 GLPi 的 REST API,而是通过…...

无网环境部署:OpenClaw离线安装Qwen3-14B镜像指南

无网环境部署:OpenClaw离线安装Qwen3-14B镜像指南 1. 为什么需要离线部署方案 在金融、政务等对数据安全要求极高的领域,服务器通常运行在严格的Air-gap环境(物理隔离网络)中。去年我在某金融机构做POC时,就遇到了这…...

网站SEO优化如何提高网站权重

网站SEO优化如何提高网站权重 在当今数字化时代,网站SEO优化已经成为提升网站权重的关键因素。无论是小型企业还是大型企业,都在为提升网站在搜索引擎结果页面上的排名而努力。如何通过SEO优化来提高网站权重呢?本文将从问题分析、原因说明、…...

MQ2_LPG气体检测库:嵌入式LPG泄漏监测与动态校准实践

1. MQ2_LPG气体检测库深度解析:面向嵌入式系统的LPG泄漏监测工程实践 1.1 库定位与工程价值 MQ2_LPG是一个专为嵌入式平台设计的轻量级气体传感驱动库,核心目标是实现对液化石油气(Liquefied Petroleum Gas, LPG)中丙烷&#xff…...

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核

OpenClaw多模态开发:Qwen2.5-VL-7B实现自动化图文内容审核 1. 为什么需要本地化内容审核 去年我接手了一个社区运营项目,每天需要审核数百张用户上传的图片和文字内容。最初尝试用第三方审核API,但很快遇到三个痛点:一是敏感数据…...

AI 伦理与可解释AI

**AI伦理与可解释AI:技术发展的双刃剑** 人工智能(AI)的快速发展正在深刻改变社会,但随之而来的伦理问题与“黑箱”难题也引发广泛讨论。AI伦理关注技术应用的道德边界,而可解释AI(XAI)则致力于…...

C++ STL 内存管理策略

C STL内存管理策略解析 C标准模板库(STL)以其高效性和灵活性成为开发者不可或缺的工具,而内存管理策略是其核心优势之一。STL通过智能分配器、容器内部机制及算法优化,实现了内存的高效利用与动态扩展。本文将深入探讨STL的内存管…...

Go测试框架与基准测试

Go测试框架与基准测试:高效代码质量的守护者 在软件开发中,测试是确保代码质量的关键环节。Go语言凭借其简洁高效的特性,内置了强大的测试工具链,包括单元测试框架和基准测试功能。无论是验证逻辑正确性,还是评估性能…...

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障

OpenClaw长期运行方案:Phi-3-mini-128k-instruct服务的稳定性保障 1. 为什么需要长期运行方案? 去年冬天的一个深夜,我被手机警报惊醒——部署在家庭服务器的OpenClaw服务崩溃了。当时正在运行的自动化周报生成任务因此中断,导致…...

Go gRPC 流通信机制详解

Go gRPC 流通信机制详解 在现代分布式系统中,高效的数据传输是核心需求之一。gRPC作为Google开源的高性能RPC框架,凭借其基于HTTP/2的流式通信能力,成为微服务通信的热门选择。Go语言因其简洁性和高并发特性,与gRPC结合尤为紧密。…...

Python高频面试题:python里面模块和包之间有什么区别?

大家好,我是锋哥。今天分享关于【Python高频面试题:python里面模块和包之间有什么区别?】面试题 。希望对大家有帮助; Python高频面试题:python里面模块和包之间有什么区别? 在 Python 里,**模…...

Java高频面试题:Netty的内存池机制怎样设计的?

大家好,我是锋哥。今天分享关于【Java高频面试题:Netty的内存池机制怎样设计的?】面试题 。希望对大家有帮助;Java高频面试题:Netty的内存池机制怎样设计的?Netty 的内存池机制是一个非常核心且复杂的部分,它的设计主…...

网络SEO的主要指标有哪些

网络SEO的主要指标有哪些 前言 在当今数字化时代,网络SEO(搜索引擎优化)是每一个网站拥有高流量和高曝光度的关键。SEO是一个复杂而又充满挑战的领域,涉及许多技术和策略。究竟有哪些是网络SEO的主要指标呢?本文将详…...

Go netpoll 实现机制分析

Go netpoll 实现机制分析 在现代高并发网络编程中,高效的事件驱动机制是提升性能的关键。Go语言通过其独特的netpoll模块,实现了轻量级且高效的I/O多路复用,支撑了Go标准库中net包的强大能力。本文将深入分析Go netpoll的实现机制&#xff0…...