LeetCode:236. 二叉树的最近公共祖先

跟着carl学算法,本系列博客仅做个人记录,建议大家都去看carl本人的博客,写的真的很好的!
代码随想录
LeetCode:236. 二叉树的最近公共祖先

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

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

示例 1:

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 1

输出:3

解释:节点 5 和节点 1 的最近公共祖先是节点 3 。

示例 2:

输入:root = [3,5,1,6,2,0,8,null,null,7,4], p = 5, q = 4

输出:5

解释:节点 5 和节点 4 的最近公共祖先是节点 5 。因为根据定义最近公共祖先节点可以为节点本身。

示例 3:

输入:root = [1,2], p = 1, q = 2

输出:1

后序遍历,如果在子树中找到了pq节点则向上返回当前节点,否则返回null

java 复制代码
	public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root == null) return null;
        if(root == p || root == q) return root;

        // 左
        TreeNode left = lowestCommonAncestor(root.left, p, q);

        //右
        TreeNode right = lowestCommonAncestor(root.right, p, q);

        // 中
        if(left != null && right != null){
            return root;
        }else if(left != null && right == null){
            return left;
        }else if(left == null && right != null){
            return right;
        }else{
            return null;
        }
    }
相关推荐
CoderCodingNo1 分钟前
【GESP】C++五级真题(贪心思想考点) luogu-P11960 [GESP202503 五级] 平均分配
开发语言·c++·算法
Caarlossss7 分钟前
mybatis
java·数据库·tomcat·maven·mybatis·mybatis-spring
喵手9 分钟前
项目实战案例:从设计到部署!
java·部署·项目实战·设计
源码获取_wx:Fegn089513 分钟前
基于springboot + vue小区人脸识别门禁系统
java·开发语言·vue.js·spring boot·后端·spring
youngee1118 分钟前
hot100-61电话号码的字母组合
java·数据结构·leetcode
POLITE323 分钟前
Leetcode 76.最小覆盖子串 JavaScript (Day 6)
javascript·算法·leetcode
寂寞旅行33 分钟前
java敏感词过滤(sensitive-word)
java·开发语言·word
90后小陈老师34 分钟前
Java项目接入AI大模型的四种方式
java·开发语言·人工智能
hunjinYang40 分钟前
使用嵌入式 Tomcat 创建Java Web应用程序
java·tomcat
Godson_beginner1 小时前
Elasticsearch 学习笔记
java·大数据·elasticsearch·搜索引擎