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

21二叉树的最近公共祖先

236. 二叉树的最近公共祖先

中等

相关标签

premium lock icon相关企业

给定一个二叉树, 找到该树中两个指定节点的最近公共祖先。

百度百科中最近公共祖先的定义为:“对于有根树 T 的两个节点 p、q,最近公共祖先表示为一个节点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。”

示例 1:

img

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1
输出:3
解释:节点 5 和节点 1 的最近公共祖先是节点 3 。

示例 2:

img

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 4
输出:5
解释:节点 5 和节点 4 的最近公共祖先是节点 5 。因为根据定义最近公共祖先节点可以为节点本身。

示例 3:

输入:root = [1,2], p = 1, q = 2
输出:1

提示:

  • 树中节点数目在范围 [2, 105] 内。
  • -109 <= Node.val <= 109
  • 所有 Node.val 互不相同
  • p != q
  • pq 均存在于给定的二叉树中。

class Solution {
public:TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {if(root == NULL) return NULL;if(root == p || root == q)  return root; //找了了目标节点,将其返回,告知上一层找到了p或者q//从底往上遍历,用后序遍历(左右中)TreeNode* lef = lowestCommonAncestor(root->left,p,q);TreeNode* rig = lowestCommonAncestor(root->right,p,q);if(lef!=NULL && rig!=NULL)  return root;  //左边和右边都有东西,说明这个是最近的公共祖先,直接返回if(lef!=NULL && rig==NULL)  return lef;  //左边有东西,将左边的p或者q返回上去if(lef==NULL && rig!=NULL)  return rig;return NULL;   //左右都找不到,返回NULL/*其实就是遍历每个节点找目标节点,然后将其向上返回,直到找到最近的公共祖先,返回值就变成了把最近的公共祖先向上返回(一共两种情况,第一种是常规的,第二种就是他俩的公共祖先是他俩中的一个),无论是哪种情况,最后返回的都是公共祖先(第二种情况遇到那个靠上的目标节点就返回了,下边压根不会遍历,本来就是他俩的公共祖先),若没有就返回NULL*/}
};
http://www.zskr.cn/news/1320818.html

相关文章:

  • 深度测评|重庆名表上门回收谁靠谱?2026 首选合扬 - 奢侈品回收测评
  • HiC-Pro跑完数据后,你的结果文件都看懂了吗?从out文件夹到可视化图谱的完整解读指南
  • 浙江宁波工作服定制厂家直供货源,劳保服定制厂家适合 长期拿货 - 奔跑123
  • 为什么 router 不会出现赋值时没值,之后才有值的情况?
  • Whisky终极指南:如何在macOS上免费运行Windows程序的完整教程
  • 为Claude Code配置稳定可靠的Taotoken后端以解决封号困扰
  • 网盘直链下载助手终极指南:一键解锁8大网盘高速下载的完整解决方案
  • 卸载工具-IObitUninstaller-Pro-v13.1.0.3下载地址及安装教程
  • 数据库优化实战:MySQL性能调优的10个核心技巧
  • 【2026最新收藏版】AI大模型七步实战学习路线图,小白/程序员必看,从零入门到高薪进阶
  • 如何快速掌握FDS火灾模拟:面向新手的完整入门指南
  • 从冒青烟到稳定运行:我的PWM整流调试血泪史与硬件安全避坑指南
  • New API:企业级AI模型聚合网关的技术架构与成本优化解决方案
  • 终极指南:如何用MPh实现COMSOL仿真自动化,提升10倍工作效率
  • Vite打包踩坑实录:解决Vue3项目在File协议下打开白屏、资源404的完整方案
  • Artisan烘焙软件:开源架构如何实现咖啡烘焙的工业级数据采集与控制?
  • 从 Maintain Business Roles 看业务角色变更记录,权限治理里最容易被忽略的一条审计线
  • 手把手教你用MATLAB实现Viterbi硬判决译码(附任意(n,k,m)卷积码完整代码)
  • 保姆级教程:用R包MaAsLin2搞定微生物组与临床数据的关联分析(附完整代码)
  • 2026年咸阳家政服务公司哪家好?育儿嫂、月嫂、保姆、保洁全方位评测 - 深度智识库
  • EvoEnv:从“出题“到“搭考场“——AI自进化的新范式
  • DRV8825驱动芯片选型避坑:从供电、散热到PCB布局的实战经验分享
  • 嵌入式系统存储分区设计:从基础方案到A/B升级与精细化管理的实战指南
  • 如何快速掌握BilibiliDown:B站视频离线下载的完整使用指南
  • 从安装失败到成功:我的Multisim 14.0卸载重装踩坑全记录(附解决方案包)
  • 龙芯2K3000与国产OS在轨道交通AFC系统中的工程实践
  • 别只盯着S参数了!射频功放设计中的负载牵引(LoadPull)与源牵引(SourcePull)实战详解
  • 在Taotoken平台管理多个项目APIKey与访问权限
  • 解锁B站4K视频下载:用Python工具轻松保存你喜欢的任何内容
  • LLaMA论文里没细说的三个“小”改进:RMSNorm、SwiGLU和RoPE到底强在哪?