题解 | #二叉搜索树的最近公共祖先#

二叉搜索树的最近公共祖先

http://www.nowcoder.com/practice/d9820119321945f588ed6a26f0a6991f

  • 利用二叉搜索树的性质,当当前节点值比p和q都要大时,说明最小公共节点在左子树上;当当前节点值比p和q都要小时,说明最小公共节点在右子树上
  • 当当前节点值介于p和q之间时,说明已经找到最近公共节点
class Solution {
public:
    int lowestCommonAncestor(TreeNode* root, int p, int q) {
        return FindAncestor(root,  p,  q)->val;
    }
    
    TreeNode* FindAncestor(TreeNode* root, int p, int q){
        if(!root) return nullptr;
        if(root->val == p || root->val == q)
            return root;
        if(p < root->val && q < root->val) return FindAncestor(root->left,  p,  q);
        else if(p > root->val && q > root->val) return FindAncestor(root->right, p, q);
        else return root;
    }
};
全部评论

相关推荐

感性的干饭人在线蹲牛友:🐮 应该是在嘉定这边叭,禾赛大楼挺好看的
点赞 评论 收藏
分享
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务