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;
    }
}
相关推荐
仰泳的熊猫9 小时前
题目2570:蓝桥杯2020年第十一届省赛真题-成绩分析
数据结构·c++·算法·蓝桥杯
似水明俊德12 小时前
02-C#.Net-反射-面试题
开发语言·面试·职场和发展·c#·.net
无极低码12 小时前
ecGlypher新手安装分步指南(标准化流程)
人工智能·算法·自然语言处理·大模型·rag
软件算法开发12 小时前
基于海象优化算法的LSTM网络模型(WOA-LSTM)的一维时间序列预测matlab仿真
算法·matlab·lstm·一维时间序列预测·woa-lstm·海象优化
无限大613 小时前
AI实战03:Java开发岗专属工作流|用AI辅助代码审查与文档生成
面试
superior tigre13 小时前
22 括号生成
算法·深度优先
程序员雨果14 小时前
软件测试工程师:面试题与经验分享
软件测试·面试·职场和发展
Yvonne爱编码14 小时前
2026年计算机专业求职指南:从简历优化到技术面试通关【科普类】
面试·职场和发展
测试界的飘柔14 小时前
月薪 20k 的性能测试面试题大曝光,让你如何迅速拿下 offer!
自动化测试·软件测试·功能测试·面试·职场和发展·职场经验·找工作