Leetcode236. 二叉树的最近公共祖先

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

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

题解:力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

代码如下:

java 复制代码
class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root == q || root == p || root == null){
            return root;
        }
        TreeNode left = lowestCommonAncestor(root.left,p,q);
        TreeNode right = lowestCommonAncestor(root.right,p,q);
        if(left != null && right != null){
            return root;
        }
        if(left == null){
            return right;
        }
        return left;

    }
}
相关推荐
关于不上作者榜就原神启动那件事36 分钟前
力扣hot100,739每日温度(单调栈)详解
算法·leetcode·职场和发展
小卡皮巴拉38 分钟前
【力扣刷题实战】丢失的数字
c++·算法·leetcode·位运算
刃神太酷啦2 小时前
排序--数据结构初阶(4)(C/C++)
c语言·数据结构·c++·算法·leetcode·深度优先·广度优先
凯子坚持 c2 小时前
深度解析算法之分治(归并)
算法·leetcode·职场和发展
PXM的算法星球8 小时前
【leetcode】3524 求出数组的X值1
算法·leetcode·职场和发展
椰羊~王小美11 小时前
LeetCode -- Flora -- edit 2025-04-27
算法·leetcode·职场和发展
mit6.82416 小时前
[Lc_week] 447 | 155 | Q1 | hash | pair {}调用
算法·leetcode·哈希算法·散列表
vim怎么退出19 小时前
43.验证二叉搜索树
前端·leetcode
编程绿豆侠20 小时前
力扣HOT100之链表:23. 合并 K 个升序链表
算法·leetcode·链表
OpenC++1 天前
【C++QT】Layout 布局管理控件详解
c++·经验分享·qt·leetcode