236.二叉树的最近公共祖先

这篇博客详细介绍了如何通过递归算法在二叉树中找到两个指定节点的最近公共祖先。首先检查根节点是否为目标节点,然后分别对左子树和右子树进行递归搜索。如果左右子树都不为空,说明根节点即为最近公共祖先;否则根据左右子树的返回结果确定最近公共祖先。该算法高效地解决了二叉树的路径查找问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

(1) 如果当前结点 root 等于 NULL,则直接返回 NULL
(2) 如果 root 等于 p 或者 q ,那这棵树一定返回 p 或者 q
(3) 然后递归左右子树,因为是递归,使用函数后可认为左右子树已经算出结果,用 leftNode 和 rightNode 表示
(4) 此时若leftNode为空,那最终结果只要看 rightNode;若 rightNode 为空,那最终结果只要看 leftNode
(5) 如果 leftNode 和 rightNode 都非空,因为只给了 p 和 q 两个结点,都非空,说明一边一个,因此 root 是他们的最近公共祖先
(6) 如果 leftNode 和 rightNode 都为空,则返回空(其实已经包含在前面的情况中了)

class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root==p||root==q) return root;
        while(root!=null){
            TreeNode leftNode=lowestCommonAncestor(root.left,p,q);
            TreeNode rightNode=lowestCommonAncestor(root.right,p,q);
            if(leftNode!=null&&rightNode!=null)
                return root;
            else if(leftNode==null){    
                return rightNode;
            }
            else return leftNode;
        }
        return null;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值