二叉树的中序遍历(java)

概述

关于二叉树,我们都不陌生,许多基于递归的问题发起点都是一个二叉树的root节点。对于各种二叉树的问题,我们也是通过dfs进行求解。例如求二叉树的深度、最近公共祖先等
在这里插入图片描述

算法分析

关于二叉树的中序遍历,我们都知道应该先访问最左边的节点,然后找到root根节点,再访问右节点。对应上图的二叉树,其中序遍历的结果应为:1 -> 2 -> 3 -> 4

算法编码

递归版本

  • 递归的中序遍历写法较为简便,只需要通过inOrder方法写在打印根节点前后的位置即可
public void inOrder(TreeNode root) {if(root == null) {return;}inOrder(root.left);System.out.print(root.value);inOrder(root.right);
}

非递归版本

  • 中序遍历二叉树我们需要优先遍历左子树,然后才是根节点。但是根节点是优先于左子树被访问到的。这种反转的先后关系(先遍历、后打印),就需要借助栈(Stack)完成

如何给出遍历的条件终止和循环也是需要考虑的,我们知道,只要根节点的左子树持续存在,我们就应该先打印左子树的节点,因此这里的逻辑就变成下述代码:

while(cur != null ) {stack.push(cur);cur = cur.left;
}
  • 如果是上面这种写法,当不存在左节点的时候,循环会跳出while部分,但是我们再取栈顶继续向后遍历的时候,依然要继续while的过程,因此我们的while条件就不能只是 cur的左子树不空,还应该加上当前栈内元素个数大于0
  • 因此上面的代码可以改为:
while(cur != null || !stack.isEmpty()) {while(cur != null ) {stack.push(cur);cur = cur.left;}
}
  • 如果cur没有左子树的情况下,我们正常执行出栈,即 stack.pop(),并打印出栈的元素。改造后的代码如下所示
while(cur != null || !stack.isEmpty()) {while(cur != null ) {stack.push(cur);cur = cur.left;}TreeNode top = st.pop();System.out.println(top.val);
}
  • 如果有右子树的情况下,cur转换为右子树,继续上述过程
while(cur != null || !stack.isEmpty()) {if(cur != null ) {stack.push(cur);cur = cur.left;}cur = st.pop();//中序遍历的顺序结果打印System.out.println(cur.val);cur = cur.right;	
}

算法总结

中序遍历在求解二叉树top-K问题的时候比较实用,可以直接通过打印、取值的情况下完成结果集的获取;如果求第k大或者第k小的元素,直接通过统计变量进行递减实现结果获取。希望大家都能清晰地掌握。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.xdnf.cn/news/1550954.html

如若内容造成侵权/违法违规/事实不符,请联系一条长河网进行投诉反馈,一经查实,立即删除!

相关文章

【C++单调队列】1438. 绝对差不超过限制的最长连续子数组|1672

本文时间知识点 C队列、双向队列 LeetCode1438. 绝对差不超过限制的最长连续子数组 给你一个整数数组 nums ,和一个表示限制的整数 limit,请你返回最长连续子数组的长度,该子数组中的任意两个元素之间的绝对差必须小于或者等于 limit 。 如…

Flume实战--Flume中的选择器、自动容灾(故障转移)、负载均衡的详解与操作

本文详细介绍了Apache Flume的关键特性,包括选择器、拦截器、故障转移和负载均衡。选择器负责将数据分发到多个Channel,拦截器用于修改或丢弃Event。故障转移机制能够在Sink故障时自动切换,而负载均衡则在多个Sink间分配负载。文章还提供了自…

CANoe_DBC能够打开但是无法使用“BusType”

解决DBC文件在CAPL中调用问题:从CANdb到CAPL的顺畅过渡 在汽车电子和嵌入式系统开发中,DBC(Database CAN)文件作为描述CAN(Controller Area Network)通信协议的重要工具,广泛应用于网络设计、测…

工作日志:ruoyi-vue-plus echarts根据窗口大小变化

1、echarts根据窗口大小变化。 onMounted(() > {// 折线图type EChartsOption echarts.EChartsOption;var chartDom document.getElementById(chartDom)!;var myChart echarts.init(chartDom);var option: EChartsOption;option {grid: {left: 35,top: 10,bottom: 30,r…

jenkins部署Maven和NodeJS项目

在 Java 项目开发中,项目的编译、测试、打包等是比较繁琐的,属于重复劳动的工作,浪费人力和时间成本。以往开发项目时,程序员往往需要花较多的精力在引用 jar 包搭建项目环境上,跨部门甚至跨人员之间的项目结构都有可能…

1.8 软件业务测试

欢迎大家订阅【软件测试】 专栏,开启你的软件测试学习之旅! 文章目录 前言1 概述2 方法3 测试策略4 案例分析 前言 在软件开发生命周期中,业务测试扮演着至关重要的角色。本文详细讲解了业务测试的定义、目的、方法以及测试策略。 本篇文章参…

C++队列、双向队列

前言 C算法与数据结构 打开打包代码的方法兼述单元测试 队列 队列(Queue)是一种基本的线性数据结构,它遵循先进先出(First In First Out, FIFO)的原则。这意味着最先被添加到队列中的元素将会是最先被移除的。和生活…

命令回显echo

命令回显 通常,make在执行命令行之前会把要执行的命令行进行输出。我们称之为“回显”,就好像我们输入命令执行一样。 如果要执行的命令行以字符“”开始,则make在执行时这个命令就不会被回显。典型的用法是我们在使用“echo”命令输出一些信…

Github 2024-09-29 php开源项目日报 Top10

根据Github Trendings的统计,今日(2024-09-29统计)共有10个项目上榜。根据开发语言中项目的数量,汇总情况如下: 开发语言项目数量PHP项目10Blade项目1Java项目1ASP项目1Coolify: 开源自助云平台 创建周期:1112 天开发语言:PHP, Blade协议类型:Apache License 2.0Star数量…

Java多线程几个哈希表的区别

HashMap 首先HashMap肯定是不行的,并没有加解锁操作,一旦多线程同时写的话,直接就会发生覆盖之类的操作 排除HashMap先,主要对比HashTable和ConcurrentHashMap HashTable vs ConcurrentHashMap 1. 加锁粒度不同 HashTable HashTable是对整个哈希表进行加锁操作,任何增删改查操…

数据结构串的kmp相关(求next和nextval)

傻瓜版,用来演示手算过程,个人理解用的,仅供参考。

CICD Jenkins实现Pipline

一、安装 1、由于 Jenkins 是基于 Java 的,首先需要确保你的系统中安装了 Java。推荐使用 OpenJDK 11。可以通过以下命令安装: apt update apt install openjdk-11-jdk2、在安装 Jenkins 之前,你需要将其仓库添加到你的系统中。首先&#x…

DotNetty ChannelRead接收数据为null

问题:C#使用Dotnetty和Java netty服务器通讯,结果能正确发送数据到服务器,却始终接收不到服务器返回的数据。 解决:一定一定要注意服务器和客户端使用的编码一定要完全一样才行 我先前在客户端添加了StringDecoder,服务器却没有…

【Spring Boot 入门一】构建你的第一个Spring Boot应用

一、引言 在当今的软件开发领域,Java一直占据着重要的地位。而Spring Boot作为Spring框架的延伸,为Java开发者提供了一种更加便捷、高效的开发方式。它简化了Spring应用的搭建和配置过程,让开发者能够专注于业务逻辑的实现。无论是构建小型的…

8.12 矢量图层面要素单一符号使用八(随机标记填充)

8.12 矢量图层面要素单一符号使用八(随机标记填充)_qgis随机填充-CSDN博客 目录 前言 随机标记填充(Random Marker Fill) QGis设置面符号为随机标记填充(Random Marker Fill) 二次开发代码实现随机标记填充(Rando…

《低空经济:文旅行业的新引擎 》

《低空经济:文旅行业的新引擎 》 一、低空经济与文旅行业的融合态势 低空经济作为新兴经济形态,正与文旅行业深度融合,为文旅发展带来新机遇。 近年来,随着科技的不断进步和人们对旅游体验的不断追求,低空经济与文旅…

Java面试常见问题总结

Java基础 Java 中的⼏种基本数据类型是什么?对应的包装类型是什么?各⾃占⽤多少字节呢? Java 中有 8 种基本数据类型,分别为: 6 种数字类型: 4 种整数型:byte、short、int、long2 种浮点型&a…

elasticsearch基础知识、go如何操作elasticsearch

【单元目标】 什么是elasticsearch? elasticsearch Analysis(分词器)概念及使用 go实现elasticsearch 搜索封装 【教学内容】 1. 什么是elasticsearch? Elasticsearch 是一个实时的分布式存储、搜索、分析的引擎。 Elasticsearch is a real-time, …

在Windows上使用谷歌浏览器的安全支付功能

在使用谷歌浏览器进行在线支付时,确保您的交易安全至关重要。本文将为您提供详细的步骤,帮助您在Windows系统上启用和使用谷歌浏览器的安全支付功能。 (本文由https://www.chromexz.com.cn/站点的作者进行编写,转载时请进行标注。…

Unity 代码裁剪(Strip Engine Code)

文章目录 0.IL2CPP 打包运行闪退问题1.什么是代码裁剪2.为什么要使用代码裁剪3.代码裁剪设置与级别4.强制保留代码4.1 使用[Preserve]标签4.2 使用Link.xml文件 5.Strip中遇到的问题及解决方法6.注意事项 0.IL2CPP 打包运行闪退问题 Google Play要求从2019年8月1日起apk必须支…