【Leetcode 每日一题】235. 二叉搜索树的最近公共祖先

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

给定一个二叉搜索树, 找到该树中两个指定节点的最近公共祖先。

百度百科中最近公共祖先的定义为:"对于有根树 T 的两个结点 p、q,最近公共祖先表示为一个结点 x,满足 x 是 p、q 的祖先且 x 的深度尽可能大(一个节点也可以是它自己的祖先)。"

例如,给定如下二叉搜索树: root = [6,2,8,0,4,7,9,null,null,3,5]

示例 1:

复制代码
输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 8
输出: 6 
解释: 节点 2 和节点 8 的最近公共祖先是 6

示例 2:

复制代码
输入: root = [6,2,8,0,4,7,9,null,null,3,5], p = 2, q = 4
输出: 2
解释: 节点 2 和节点 4 的最近公共祖先是 2, 因为根据定义最近公共祖先节点可以为节点本身。

说明:

  • 所有节点的值都是唯一的。
  • p、q 为不同节点且均存在于给定的二叉搜索树中。

思路:

要找到最近的公共父节点,因为给的已经是二叉树了,也就是父节点的左子树中的节点值均比父节点的值小,右子树中节点的值均比父节点打,所以我们要找到的就是p和q分别在哪一个节点之后分布在了父节点两侧,从上往下遍历即可,当在一侧的时候就进行继续向下遍历。这也考虑到了一个节点也可以是它自己的祖先这个问题,因为移动到一个节点作为祖先的时候显然不满足均小于这个祖先节点的值,跳出循环结束。

代码:

cpp 复制代码
/**
 * 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) {
    TreeNode* ancester = root;
    while(true){
        if(p->val < ancester->val && q->val < ancester->val){
            ancester = ancester->left;
        }
        else if(p->val > ancester->val && q->val > ancester->val){
            ancester = ancester->right;
        }
        else{
            break;
        }
    }
    return ancester;
    }
};
相关推荐
飞Link14 分钟前
深度解析 MSER 最大稳定极值区域算法
人工智能·opencv·算法·计算机视觉
bubiyoushang88819 分钟前
基于CLEAN算法的杂波抑制Matlab仿真实现
数据结构·算法·matlab
2401_894828121 小时前
从原理到实战:随机森林算法全解析(附 Python 完整代码)
开发语言·python·算法·随机森林
Remember_9931 小时前
【LeetCode精选算法】前缀和专题二
算法·哈希算法·散列表
源代码•宸1 小时前
Leetcode—509. 斐波那契数【简单】
经验分享·算法·leetcode·面试·golang·记忆化搜索·动规
博大世界2 小时前
matlab结构体数组定义
数据结构·算法
Loo国昌2 小时前
【LangChain1.0】第九阶段:文档处理工程 (LlamaIndex)
人工智能·后端·python·算法·langchain
Zach_yuan2 小时前
面向对象封装线程:用 C++ 封装 pthread
开发语言·c++·算法
踩坑记录3 小时前
leetcode hot100 206.反转链表 easy
leetcode
安特尼3 小时前
X 推荐算法分析
算法·机器学习·推荐算法