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

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

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;
    }
};
全部评论

相关推荐

不愿透露姓名的神秘牛友
06-27 15:07
点赞 评论 收藏
分享
nus2201602...:兄弟,你这个简历撕了丢了吧,就是一坨,去找几个项目,理解项目流程,看几遍就是你的了,看看八股就去干了,多看看牛客里别人发出来的简历,对着写,你这写的啥啊,纯一坨
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务