【力扣刷题练习】236. 二叉树的最近公共祖先

题目描述:

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

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

题目解答:

cpp 复制代码
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(root == nullptr || root == p || root == q)
            return root;
        TreeNode* left = lowestCommonAncestor(root->left, p, q);
        TreeNode* right = lowestCommonAncestor(root->right, p, q);
        if(left == nullptr||right == nullptr)
            return left==nullptr?right:left;
        return root;
    }
};

题目思路:

递归左右子树,寻找 p 和 q 的最近公共祖先。

如果左子树或右子树中有一个是空(也就是说,这个子树没有公共祖先),那么返回非空的子树中的结果。

最后,如果左子树和右子树都找到了公共祖先(也就是说,它们都不为空),那么当前的节点 root 就是 p 和 q 的最近公共祖先。所以,返回 root。

相关推荐
客梦几秒前
数据结构-栈与队列
数据结构·笔记
chao1898442 分钟前
MATLAB 实现声纹识别特征提取
人工智能·算法·matlab
zhishidi4 分钟前
推荐算法之:GBDT、GBDT LR、XGBoost详细解读与案例实现
人工智能·算法·推荐算法
货拉拉技术5 分钟前
货拉拉RAG优化实践:从原始数据到高质量知识库
数据库·算法
AKDreamer_HeXY15 分钟前
ABC434E 题解
c++·算法·图论·atcoder
罗湖老棍子15 分钟前
完全背包 vs 多重背包的优化逻辑
c++·算法·动态规划·背包
TL滕16 分钟前
从0开始学算法——第四天(题目参考答案)
数据结构·笔记·python·学习·算法
potato_may26 分钟前
C++ 发展简史与核心语法入门
开发语言·c++·算法
Liangwei Lin28 分钟前
洛谷 P1443 马的遍历
数据结构·算法
老鱼说AI30 分钟前
算法基础教学第二步:数组(超级详细原理级别讲解)
数据结构·神经网络·算法·链表