【LeetCode-中等题】236. 二叉树的最近公共祖先

文章目录

    • 题目
    • [方法一:后序遍历 + 回溯](#方法一:后序遍历 + 回溯)

题目

方法一:后序遍历 + 回溯

解题的核心就是:采用后序遍历

  1. 讨论p,q是否在当前的root的两边,如在两边则返回当前节点root
  1. 如何不在两边,只要出现一个节点等于p或者q就返回当前节点
java 复制代码
// 后序遍历  + 回溯
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q) {
        if(root == null) return null;//即做节点判空条件、、也做递归出口 (说明递归到null  都没有找到  p或q)

        if(root == p || root == q)  return root;//  说明(当前要递归的节点就是p或q直接返回)或递归找到了p或q  就不用再往下递归了 结束此次递归  返回 p 或 q

        TreeNode left = lowestCommonAncestor(root.left,p,q);//递归左子树,返回值就是找到的p或q  没找到就是null
        TreeNode right = lowestCommonAncestor(root.right,p,q);//递归右子树返回值就是找到的p或q  没找到就是null

        if(left!=null  && right!=null) return root;
        // 如果遍历左右子树 在左子树或右子树找到了都找到了(  p  或  q  )
        //  说明当前结点就是  p  q  的最近公共祖先
        
        if(left != null && right == null) return left;
        //如果当前遍历左右子树结点只找到  一个 (q 或者 p)
        //说明下一个p或者q其实就是在这个结点下面 因为一旦找到了p 或q就不会往下遍历了,
       // 所以一旦出现只能找到一个(q  或  p)的情况 说明这个这个节点即是(p 或 q) 又是q 和 p 的最近公共祖先
        if(right != null && left==null) return right; 

        return null;//所有都不满足直接返回null
    }

二叉树的最近公共祖先(DFS ,清晰图解)

相关推荐
chao18984412 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙12 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰13 小时前
倍增算法和ST表
算法
知识领航员14 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪14 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声15 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠15 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan15 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算
爱喝雪碧的可乐16 小时前
2026 腾讯广告算法大赛优秀方案启示:行为条件化多模态自回归生成推荐摘要
算法·数据挖掘·回归·推荐系统·推荐算法