二叉树之自底向上递归

本文介绍了二叉树的两种自底向上递归解题思路,包括236. 二叉树的最近公共祖先和652. 寻找重复的子树。解法分别涉及深度遍历,利用递归找到最近公共祖先和记录重复子树。通过自底向上的递归,先遍历再处理,解决了这两个问题。时间复杂度均为O(N),空间复杂度最高为O(N)。
摘要由CSDN通过智能技术生成

二叉树我们知道使用递归代码会比较简洁,而这些递归题型中大部分题目都是自上向底(正常思维)进行递归,也有自底往上进行递归的题目,以下汇总两道比较典型的:

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

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

例如,给定如下二叉树:  root = [3,5,1,6,2,0,8,null,null,7,4]
示例 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。因为根据定义最近公共祖先节点可以为节点本身。

解法:自底往上递归
思路:先深度遍历改树。当你遇到节点 p 或 q 时,返回一些布尔标记。 该标志有助于确定是否在任何路径中找到了所需的节点。最不常见的祖先将是两个子树递归都返回真标志的节点。它也可以是一个节点,它本身是p或q中的一个,对于这个节点,子树递归返回一个真标志。
算法实现:

  • 1 从根节点开始遍历树。
  • 2 如果当前节点本身是 p 或 q 中的一个,我们会将变量 mid 标记为 true,并继续搜索左右分支中的另一个节点。
  • 3 递归(下探):如果左分支或右分支中的任何一个返回 true,则表示在下面找到了两个节点中的一个。
  • 4 process: 如果在遍历的任何点上,左、右或中三个标志中的任意两个变为 true,这意味着我们找到了节点 p 和 q 的最近公共祖先。

时间复杂度:O(N),N 是二叉树中的节点数,最坏情况下,我们需要访问二叉树的所有节点。
空间复杂度:O(N),这是因为递归堆栈使用的最大空间位 N,斜二叉树的高度可以是 N。

代码:
class Solution {
       

    private TreeNode ans = null; //用于存储找到的最近公共祖先
    public TreeNode lowestCommonAncestor(TreeNode root, TreeNode p, TreeNode q){
   
        // 遍历整个树
        recurseTree(root,p,q);
        return ans;
    }
    private boolean recurseTree(TreeNode currentNode
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值