【力扣刷题练习】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。

相关推荐
炽烈小老头17 小时前
【 每天学习一点算法 2026/03/19】子集
学习·算法
我能坚持多久17 小时前
【初阶数据结构11】——链式二叉树知识补充
数据结构·算法
liuyao_xianhui17 小时前
优选算法_两数之和_位运算_C++
java·开发语言·数据结构·c++·算法·链表·动态规划
靠沿17 小时前
【优选算法】专题十六——BFS解决最短路径问题
redis·算法·宽度优先
博风17 小时前
算法:双指针解:盛最多水的容器
算法·leetcode
童话ing18 小时前
【Golang】Golang Map数据结构底层原理
数据结构·golang·哈希算法
夏乌_Wx18 小时前
图 | 3道LeetCode常见笔试、面试题汇总
算法
wWYy.18 小时前
左值引用和右值引用
数据结构
ZPC821018 小时前
PPO训练小车
人工智能·算法·机器人
阿Y加油吧18 小时前
力扣打卡day05——找到字符串中所有字母异位词、和为K的子数组
leetcode