力扣.面试题 04.06. 后继者(java 树的中序遍历)

Problem: 面试题 04.06. 后继者

文章目录

题目描述

设计一个算法,找出二叉搜索树中指定节点的"下一个"节点(也即中序后继)。

如果指定节点没有对应的"下一个"节点,则返回null。

思路

由于题意是找出一个在二叉搜索树中给定的节点的后继节点 ,按示例意思可知道为求二叉搜索树中序遍历递增序列中给定一个节点的相邻的下一个更大的值 ,进一步分析可得为利用二叉搜索树中序遍历的得出递增序列,再在此基础上求取一给定值的下一个比给定值大的值

解题方法

1.定义两个成员变量,一个用于记录在中序遍历过程中,当前节点是否为指定节点(假设为comming 返回类型为boolean),一个用于返回最后的结果(假设为succession 返回类型为TreeNode)(由于本解法用到递归处理二叉树的中序遍历,所以定义两个成员变量用于辅助记录!)

2.中序遍历查找指定节点,若当前节点是指定节点,则将comming修改为true,当再在递归过程中判断comming为true时 则表示当前节点为指定节点的下一个节点 ,将当前节点指向succession,最后返回即可。

3.注意:在递归过程中若判断succession不为null时说明已经找到后继节点,则可以提前结束递归!!!

复杂度

  • 时间复杂度:

O ( n ) O(n) O(n)

  • 空间复杂度:

O ( n ) O(n) O(n)

Code

java 复制代码
/**
 * Definition for a binary tree node.
 * public class TreeNode {
 *     int val;
 *     TreeNode left;
 *     TreeNode right;
 *     TreeNode(int x) { val = x; }
 * }
 */
class Solution {
    //Time Complexity: O(n)
    //Space Complexity: O(n)

    //用与记录下一个
    private boolean comming = false;
    private TreeNode successor = null;
    public TreeNode inorderSuccessor(TreeNode root, TreeNode p) {
        inOrder(root,p);
        return successor;
    }

    private void inOrder(TreeNode root, TreeNode p) {
        if (root == null) {
            return;
        }
        inOrder(root.left,p);
        if (successor != null) {
            return;
        }
        //如果上一个节点是指定节点
        if (comming == true) {
            successor = root;
            comming = false;
        }
        //入果当前节点是指点节点
        //将comming设置为true
        if (root == p) {
            comming = true;
        }
        inOrder(root.right,p);
    }
}
相关推荐
小苏兮6 分钟前
【C++】priority_queue和deque的使用与实现
开发语言·c++·学习
货拉拉技术23 分钟前
网关 MCP 转换技术:从实现到平台落地
java·架构·mcp
艾菜籽24 分钟前
SpringMVC练习:加法计算器与登录
java·spring boot·spring·mvc
啊森要自信25 分钟前
【GUI自动化测试】Python 自动化测试框架 pytest 全面指南:基础语法、核心特性(参数化 / Fixture)及项目实操
开发语言·python·ui·单元测试·pytest
赵谨言36 分钟前
基于python智能家居环境质量分析系统的设计与实现
开发语言·经验分享·python·智能家居
元亓亓亓1 小时前
考研408--组成原理--day1
开发语言·javascript·考研·计组
仰泳的熊猫1 小时前
LeetCode:538. 把二叉搜索树转换为累加树/1038. 从二叉搜索树到更大和树
数据结构·c++·算法·leetcode
Yurko131 小时前
【C语言】环境安装(图文)与介绍
c语言·开发语言·学习
浮游本尊1 小时前
Java学习第25天 - Spring Cloud Alibaba微服务生态
java
仲星(._.)1 小时前
C语言:字符函数和字符串函数
c语言·开发语言