LeetCode 235/236 LCA问题(Python)

LCA问题

LCA问题定义为,给定一个二叉树,找到树中两个指定节点的最近公共祖先。(来源于LeetCode 236

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

如下图所示二叉树:
节点5和节点1的最近公共祖先的节点3,节点5和节点4的最近公共祖先是节点5。
如图示二叉树,节点5和节点1的最近公共祖先的节点3,节点5和节点4的最近公共祖先是节点5。


二叉搜索树

在解决上述问题之前,我们先提一个概念——二叉搜索树。
二叉搜索树,也称二叉查找树(Binary Search Tree)维基百科上对其定义为一棵空树或者具有以下性质的二叉树

  1. 若任意节点的左子树不空,则左子树上所有节点的值均小于它的根节点的值;
  2. 若任意节点的右子树不空,则右子树上所有节点的值均大于它的根节点的值;
  3. 任意节点的左、右子树也分别为二叉查找树;
  4. 没有键值相等的节点。

二叉搜索树的LCA问题(LeetCode 235)

如果把上述LeetCode 236中的二叉树换为二叉搜索树,便得到了二叉搜索树的LCA问题。
在这里插入图片描述
简单来说,二叉搜索树是二叉树中一个特例,因此题目在给我们二叉搜索树时,我们一定要往二叉搜索树的特有性质上想。而二叉搜索树最大的特点是 必然满足其左节点< 根节点 <右节点(当然前提是这些节点存在)。


解题思路

这时,我们就可以利用这个思路来解决问题。
给定的两节点p,q都小于根节点时,我们就可以直接到左子树里去寻找公共祖先,因为根据上述的性质,肯定和根节点、右子树都没关系了;
同理,当给定的两节点p,q都大于根节点时,我们就可以直接到右子树里去寻找公共祖先
剩下的情况就只有p,q其一小于或等于根节点,另一大于或等于根节点,这时我们就可以直接判断该根节点是公共祖先


递归
class Solution:
    def lowe
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值