二叉树的最近公共祖先

二叉树的最近公共祖先

问题:

在这里插入图片描述
在这里插入图片描述

思路:

分治递归:

在二叉树中寻找节点p,q:要么p或q为根节点,在这种情况下,根节点即为最近公共祖先。要么p,q 分布在左子树或右子树中。若p,q分别分布在左右子树,根节点即为最近公共祖先,若p,q都处于左子树或右子树中,则处理对象变为根的左子树或右子树,对左子树或右子树递归求解。

递归函数的功能为寻找节点p,q的最近公共祖先,若根节点即为p或q,直接返回根节点,否则对左子树和右子树分别调用递归函数。若对左子树调用递归函数的返回值为空指针,表明p,q均在右子树中,返回对右子树调用递归函数的返回值(处理对象变为右子树,因为p,q均在右子树中)。若对右子树调用递归函数的返回值为空指针,表明p,q均在左子树中,返回对左子树调用递归函数的返回值(处理对象变为左子树,因为p,q均在左子树中)。若对左右子树调用递归函数的返回值均不为空,表明p,q分别处于左右子树中,此时根节点即为最近公共祖先,返回根节点。

代码:

/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
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;
    }
};
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

happy19991001

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值