day54(1.5)——leetcode面试经典150

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

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

//这个方法真的好聪明啊,首先先判断是否走到p,或者走到q的位置,还是走到叶节点

//然后进行递归,看p,q是否在左子树上

//看p,q是否在右子树上

//如果发现左子树或者右子树其中一个为空,这就说明其中一个p/q是不同时存在于一个root中,所以不断返回找到的值

//但是如果left和right都返回了值,不为空,则就说明root就是他们的最近祖先

//我感觉还是得在例子上进行实操一下逻辑更好理解

每一次写算法题我都觉得这些思路简直太神了

题目:

题解:

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root == null || root == p || root == q) {
            return root;
        }
        TreeNode left = lowestCommonAncestor(root.left, p, q);
        TreeNode right = lowestCommonAncestor(root.right, p, q);
        if(left == null) {
            return right;
        }
        if(right == null) {
            return left;
        }
        return root;
    }
}
相关推荐
闲看云起8 小时前
LeetCode-day5:三数之和
算法·leetcode·职场和发展
Xの哲學8 小时前
Linux 文件系统一致性: 从崩溃恢复到 Journaling 机制
linux·服务器·算法·架构·边缘计算
wtmReiner8 小时前
山东大学数值计算2026.1大三上期末考试回忆版
笔记·算法
黛色正浓8 小时前
leetCode-热题100-滑动窗口合集(JavaScript)
javascript·算法·leetcode
漫随流水8 小时前
leetcode算法(145.二叉树的后序遍历)
数据结构·算法·leetcode·二叉树
Tony_yitao9 小时前
22.华为OD机试真题:数组拼接(Java实现,100分通关)
java·算法·华为od·algorithm
2501_941875289 小时前
在东京复杂分布式系统中构建统一可观测性平台的工程设计实践与演进经验总结
c++·算法·github
sonadorje9 小时前
梯度下降法的迭代步骤
算法·机器学习
漫随流水9 小时前
leetcode算法(94.二叉树的中序遍历)
数据结构·算法·leetcode·二叉树
范纹杉想快点毕业9 小时前
嵌入式通信核心架构:从状态机、环形队列到多协议融合
linux·运维·c语言·算法·设计模式