news 2026/4/16 15:22:16

LeetCode(python)——236.二叉树的最近公共祖先

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode(python)——236.二叉树的最近公共祖先

题目

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

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

示例 1:

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

示例 2:

输入: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均存在于给定的二叉树中。

思路

规律:p、q节点要么在分叉点(最近公共祖先就是分叉交点),要么在同一边(最近公共祖先是两者中的一个)

利用后序遍历去找左右子树,如果找到p、q则返回,如果为空(没找到p、q)返回None

用left去记录遍历左子树的结果

用right去记录遍历右子树的结果

有4种情况:
(1)left、right == null,说明都没有找到,p、q节点不在当前访问的节点的左右子树上,return None

(2)left为空,right不为空,说明p、q在右子树中,那么right就是最近公共祖先,return right(left不为空,right为空同理)

(3)left、right都不为空:说明p、q在当前访问的节点的左右子树上,当前节点就是最近公共祖先,return node

代码

# Definition for a binary tree node. # class TreeNode: # def __init__(self, x): # self.val = x # self.left = None # self.right = None class Solution: def lowestCommonAncestor(self, root: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode': return self.f(root, p ,q) # 递归函数:利用后序遍历在左右子树中找p、q def f(self, node: 'TreeNode', p: 'TreeNode', q: 'TreeNode') -> 'TreeNode': if node == None or node == p or node == q: # 如果当前节点是p、q直接返回 return node left = self.f(node.left, p, q) # 往左子树找 right = self.f(node.right, p, q) # 往右子树找 if left == None and right == None: return None # 如果都为空,说明不在当前节点下 if left and right: return node # 如果都不为空,说明分别位于当前节点的左右子树,那么当前节点就是LCA return left if left else right # 如果其中一个为空,一个不为空,说明p、q在同一边,那么不为空的left/right就是LCA
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 9:04:50

CTF基本赛制与题型

CTF|基本赛制与题型 1. 什么是CTF&#xff1f; CTF&#xff08;Capture The Flag&#xff09;直译为“夺旗赛”&#xff0c;起源于1996年举办的DEF CON全球黑客大会最早是交流安全技术的重要途径。随着时间的退役&#xff0c;CTF竞赛逐渐演变成为信息安全技术竞赛的一种形式&a…

作者头像 李华
网站建设 2026/4/16 9:01:59

PCB焊锡桥连与拉尖成因分析与工艺优化方案

在 PCB 焊接缺陷中&#xff0c;桥连和拉尖是最常见的两种外观缺陷&#xff0c;尤其在高密度细间距 PCB 的焊接中&#xff0c;这两个问题更是让工程师头疼不已。桥连是指相邻两个焊点之间被焊锡连接&#xff0c;导致短路&#xff1b;拉尖是指焊点末端出现尖锐的焊锡突起&#xf…

作者头像 李华
网站建设 2026/4/16 9:03:38

教育领域新应用:用EmotiVoice生成带情绪的教学音频

教育领域新应用&#xff1a;用EmotiVoice生成带情绪的教学音频 在在线教育迅速普及的今天&#xff0c;一个看似微小却影响深远的问题正困扰着无数教师和课程开发者——为什么学生总是听着听着就走神了&#xff1f; 答案或许藏在声音里。传统的教学音频大多由标准语音合成系统…

作者头像 李华
网站建设 2026/4/16 10:44:32

高温高湿环境下PCB焊锡失效机理与防护措施

在新能源汽车、工业控制、户外通讯等领域&#xff0c;PCB 需要长期工作在高温高湿的恶劣环境下&#xff0c;焊锡焊点的失效问题尤为突出。数据显示&#xff0c;在 85℃/85% RH 的环境下&#xff0c;PCB 焊锡焊点的寿命会缩短 50% 以上&#xff0c;这给产品的可靠性带来了巨大挑…

作者头像 李华
网站建设 2026/4/15 23:18:39

浅谈《三国:谋定天下》的轻度化设计:SLG减负的新方向

策略小白最近想玩一下SLG游戏&#xff0c;由于早年间玩过《万国觉醒》&#xff0c;但是因为没啥付费能力跟不上队友步伐退游了&#xff0c;所以这次在玩之前先分析下自己的画像&#xff1a;付费能力不强&#xff0c;没有付费习惯没有大块儿时间一直盯着游戏习惯快速反馈&#x…

作者头像 李华