当前位置: 首页 > 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.jsqmd.com/news/846097/

相关文章:

  • 2026最新 汉川市黄金回收白银回收铂金回收店铺实力排行榜TOP5;五家靠谱回收门店联系方式推荐_转自TXT - 盛世金银回收
  • vllm -- 源码学习1(寻找源码入口) (小白级教程)
  • 深度测评|重庆名表上门回收谁靠谱?2026 首选合扬 - 奢侈品回收测评
  • 程序员必知的10个设计模式:从理论到代码的全面解析
  • LK220N10
  • 解密冰蝎和蚁剑:在CTF流量分析中如何识别和还原WebShell攻击(含AES/Base64解密实操)
  • 高效过滤新选择:品质保障压滤机江苏厂家推荐 - 品牌2025
  • 浙江宁波工作服定制厂家直供货源,劳保服定制厂家适合 长期拿货 - 奔跑123
  • 如何高效构建智能投资助手:韭菜盒子VSCode插件的7大核心功能深度解析
  • 为什么 router 不会出现赋值时没值,之后才有值的情况?
  • 官方认证|2026年云南五大正规职业装 / 学生校服 / 文体用品定制批发企业排名,向日葵综合实力遥遥领先 - 十大品牌榜
  • 秘鲁国际商标注册平台哪家最好?2026 代理机构资质 + 服务 + 费用测评 - 速递信息
  • 生成式 AI 的成本暗礁:FinOps 如何照亮从试点到规模化的全链路
  • 卸载工具-IObitUninstaller-Pro-v13.1.0.3下载地址及安装教程
  • DiffuGen:基于扩散模型的代码生成技术原理与应用前景
  • 从0到1的15个月:割草机器人研发通关全景
  • 岩棉板优缺点全解析:从住宅外墙到工业现场的真实视角 - 奔跑123
  • 2026年北京短视频代运营与AI搜索优化服务商深度评测:企业精准获客完整指南 - 企业名录优选推荐
  • 轻量级服务器配置分发工具cc-sdd:基于SSH的批量运维利器
  • 你的项目该用CSR还是SSR?从ToB后台到ToC电商的实战选型指南
  • Taotoken稳定直连与路由策略保障了我的线上服务SLA
  • 从YOLOX到RK3588:手把手教你用RKNN-Toolkit2完成模型转换与部署(含Python/C++完整代码)
  • 南京爱屋建筑防水:雨花台地下室防水找哪家 - LYL仔仔
  • 2026年北京抖音推广、GEO优化与短视频代运营服务商选型指南 - 企业名录优选推荐
  • 5步掌握AntiDupl.NET:终极免费图片去重工具,轻松释放硬盘空间
  • D2DX技术重生:3步让《暗黑破坏神2》在Windows 11重获新生
  • New API:企业级AI模型聚合网关的技术架构与成本优化解决方案
  • 如何将网易云音乐NCM文件转换为通用音频格式
  • 浙江宁波招投标工作服定制厂家,合规劳保服定制厂家政企优选 - 奔跑123
  • 2026年宁夏银川B2B企业获客与AI营销深度横评:短视频、GEO优化、智能体一站式解决方案 - 精选优质企业推荐官