[LeetCode][LCR 193]二叉搜索树的最近公共祖先

题目

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

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

例如,给定如下二叉搜索树:
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 为不同节点且均存在于给定的二叉搜索树中。

注意:本题与主站 235 题相同:LeetCode - Lowest Common Ancestor of a Binary Search Tree

解法:

  1. 本题给的二叉树为二叉搜索树,当节点值比 root 小,则在 root->left 上,反之则在 root->right 上
  2. 如果都在 root->left 上,则在左子树进行搜索,反之在右子树进行搜索
  3. 如果在 root 两侧,则 root 即为最近公共祖先

cpp 复制代码
class Solution {
public:

    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(p->val > q->val) swap(p, q); // 保证 p 的值小于等于 q 的值

        if(p->val <= root->val && q->val >= root->val) return root; // 如果 p、q 分别在 root 的两侧,说明 root 就是最近公共祖先
        if(q->val < root->val) return lowestCommonAncestor(root->left, p, q); // 如果 p、q 都在 root 的左侧,则递归左子树
        if(p->val > root->val) return lowestCommonAncestor(root->right, p, q); // 如果 p、q 都在 root 的右侧,则递归右子树

        return nullptr; // 默认情况下返回空指针
    }
};
相关推荐
星火开发设计3 小时前
枚举类 enum class:强类型枚举的优势
linux·开发语言·c++·学习·算法·知识
嘴贱欠吻!9 小时前
Flutter鸿蒙开发指南(七):轮播图搜索框和导航栏
算法·flutter·图搜索算法
张祥6422889049 小时前
误差理论与测量平差基础笔记十
笔记·算法·机器学习
踩坑记录9 小时前
leetcode hot100 2.两数相加 链表 medium
leetcode·链表
qq_192779879 小时前
C++模块化编程指南
开发语言·c++·算法
cici1587411 小时前
大规模MIMO系统中Alamouti预编码的QPSK复用性能MATLAB仿真
算法·matlab·预编码算法
历程里程碑11 小时前
滑动窗口---- 无重复字符的最长子串
java·数据结构·c++·python·算法·leetcode·django
2501_9403152612 小时前
航电oj:首字母变大写
开发语言·c++·算法
CodeByV13 小时前
【算法题】多源BFS
算法
TracyCoder12313 小时前
LeetCode Hot100(18/100)——160. 相交链表
算法·leetcode