二叉树中任意两个节点的最近公共祖先

Posted 爱简单的Paul

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树中任意两个节点的最近公共祖先相关的知识,希望对你有一定的参考价值。

public class Solution {  
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {  
        //发现目标节点则通过返回值标记该子树发现了某个目标结点  
        if(root == null || root == p || root == q) return root;  
        //查看左子树中是否有目标结点,没有为null  
        TreeNode left = lowestCommonAncestor(root.left, p, q);  
        //查看右子树是否有目标节点,没有为null  
        TreeNode right = lowestCommonAncestor(root.right, p, q);  
        //都不为空,说明做右子树都有目标结点,则公共祖先就是本身  
        if(left!=null&&right!=null) return root;  
        //如果发现了目标节点,则继续向上标记为该目标节点  
        return left == null ? right : left;  
    }  
}  

感觉很奇妙

以上是关于二叉树中任意两个节点的最近公共祖先的主要内容,如果未能解决你的问题,请参考以下文章

在二叉树中找到两个节点最近公共祖先

在二叉树中找到两个节点的最近公共祖先

python代码实现二叉树中最低的公共祖先

二叉树进阶题------最近公共祖先

二叉树进阶题------最近公共祖先

236. 二叉树的最近公共祖先[中等]