LeetCode刷题笔记 236 / 剑指Offer 68

题目:二叉树的最近公共祖先
在这里插入图片描述
答案:

参考链接:JAVA DFS+剪枝

递归

我们使用DFS搜索每一个节点的左右子树:
1、若子树上存在p和q的公共节点,返回此公共节点
2、若不存在公共节点,但是存在p或q任意一个节点,返回此节点
3、若不存在公共、p、q节点,则返回null。

那么,有以下几个结论:
1、若当前节点为null、p、q之一,直接返回当前节点
2、若左子树上存在公共节点(返回值非p、q),则函数返回值为左子树返回值,不需再遍历右子树(剪枝)
3、若左子树、右子树返回值均为非null,则肯定为一个p,一个q,则公共节点为当前节点,返回当前结点。
4、如果左右子树其中一个不为空,则返回非空子树节点。

*针对p是q的子节点这种特殊情况,上述方案依然可行(但就没有办法剪枝了,可以考虑针对此情况加一个标记,不再遍历右子树)。

举例:二叉树如下, p为9,q为11.

        1
       / \
     2     3
    / \   / \
  4   5   6   7
 / \  /\  /\  /\
8  9 10 11      13

以8为根的子树返回null,以9为根的子树返回9,以4为根的子树返回9;以10为根的子树返回null,以11为根的子树返回11,以5为根的子树返回11;以2为根的子树返回2(因为左右子树返回值都不为空,所以2为公共节点)以1为根的节点返回2(因为2不等于9也不等于11,所以2是已经求得的公共节点,就无需再遍历3及以下的右子树了)

代码:

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if (root == null || root == p || root == q) {          //情况1
            return root;
        }
        TreeNode left = lowestCommonAncestor(root.left, p, q); 
        if (left != null && left != q && left != p)            //情况2
            return left;
        TreeNode right = lowestCommonAncestor(root.right, p, q);
        if (left != null && right != null) {                   //情况3
            return root;
        }
        return left!=null ? left : right;                      //情况4
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值