leetcode刷题记录 二叉树的最近公共祖先

本文介绍了LeetCode中二叉树的最近公共祖先问题的解题思路,通过后序遍历的方式寻找节点。当遇到目标节点p或q时,回溯判断是否满足最近公共祖先条件,即它们位于当前节点的异侧。代码实现中,如果找到p和q或者只找到一个,都会返回当前节点作为结果。

leetcode 二叉树的最近公共祖先

在这里插入图片描述
解题思路:
根据以上定义,若 rootroot 是 p, qp,q 的 最近公共祖先 ,则只可能为以下情况之一:

  1. p和 q在 root的子树中,且分列 root的 异侧(即分别在左、右子树中);
  2. p = root,且q在root的左或右子树中;
  3. q = root,且p在root的左或右子树中;

考虑通过递归对二叉树进行后序遍历,当遇到节点 p 或 q 时返回。从底至顶回溯,当节点 p, q 在节点 root 的异侧时,节点 root即为最近公共祖先,则向上返回 root 。

在这里插入图片描述
代码如下:

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode 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)
            return right;
        if(right == null)
            return left;
        return root;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值