二叉树及其三种遍历方式的实现(基于Java)
二叉树概念:
- 二叉树是每个节点的度均不超过2的有序树,因此二叉树中每个节点的孩子只能是0,1或者2个,并且每个孩子都有左右之分。
- 位于左边的孩子称为左孩子,位于右边的孩子成为右孩子;以左孩子为根节点的子树称其为左子树,右孩子为根节点的子树成为右子树。
- 二叉树可以使用顺序表(数组)来存储其节点,并且节点的存储位置即为数组的下标索引。
遍历:将二叉树中的节点信息由非线性排列变为某种意义上的线性排列,即遍历操作是非线性结构线性化。
结构如图所示:

三种遍历方式:
1.前序遍历
基本思想:首先访问根节点,然后前序遍历其左子树,最后前序遍历右子树。注意:遍历左右子树,依旧使用前序遍历
2.中序遍历
基本思想:首先中序遍历根节点的左子树,然后访问根节点,最后中序遍历其右子树。注意:遍历左右子树,依旧使用中序遍历
3.后序遍历
基本思想:首先后续遍历根节点的左子树,然后后序遍历根节点的右子树,最后访问其根节点。注意:遍历左右子树,依旧使用后序遍历
基于Java代码来实现上述三种遍历方式:
import java.util.List;
public class ArrayBinaryTree<T> {
//一颗二叉树
private T[] arr;
//数据不能为空(数据为空,遍历无意义)
public ArrayBinaryTree(T[] arr){
if(arr == null || arr.length == 0){
throw new IllegalArgumentException("arr must not null");
}
this.arr = arr;
}
//前序遍历
public void preOrder(int index, List<T> result){
result.add(arr[index]);
if(2 * index +1 < arr.length){
preOrder(2 * index +1,result);
}
if(2 * index + 2 < arr.length){
preOrder(2 * index + 2,result);
}
}
//中序遍历
public void infixOrder(int index,List<T> result){
if(2 * index +1 <arr.length){
infixOrder(2 * index + 1,result);
}
result.add(arr[index]);
if(2 * index + 2 < arr.length){
infixOrder(2 * index + 2,result);
}
}
//后序遍历
public void postOrder(int index,List<T> result){
if(2 * index +1<arr.length){
postOrder(2 * index + 1,result);
}
if(2 * index + 2 < arr.length){
postOrder(2 * index +2,result);
}
result.add(arr[index]);
}
}
单元测试:
import java.util.ArrayList;
public class ArrayBinaryTreeTest {
public static void main(String[] args){
Integer[] arr = {1,2,4,3,5,6};
ArrayList<Integer> result = new ArrayList<>(arr.length);
ArrayBinaryTree<Integer> arrayBinaryTree = new ArrayBinaryTree<>(arr);
arrayBinaryTree.preOrder(0,result);
System.out.println(result);
String[] arr1 = {"A","B","C","D","E","F","G","H","I","J"};
ArrayList<String> result_str = new ArrayList<>(arr1.length);
ArrayBinaryTree<String> arrayBinaryTree1 = new ArrayBinaryTree<>(arr1);
arrayBinaryTree1.postOrder(0,result_str);
System.out.println(result_str);
}
}
这里测试了前序遍历和后序遍历,中序遍历可自行测试!结果都正确!!!
测试结果:

至此,关于二叉树的前中后三种遍历方法及其代码实现介绍完毕!!!!!!
二叉树及其三种遍历方式的实现(基于Java)的更多相关文章
- 基于Java的二叉树的三种遍历方式的递归与非递归实现
二叉树的遍历方式包括前序遍历.中序遍历和后序遍历,其实现方式包括递归实现和非递归实现. 前序遍历:根节点 | 左子树 | 右子树 中序遍历:左子树 | 根节点 | 右子树 后序遍历:左子树 | 右子树 ...
- HashMap概述及其三种遍历方式
一.HashMap概述: 1.HashMap是一个散列表,它存储的是键值对(key-value)映射: 2.HashMap继承AbstractMap,实现了Map,Cloneable,Serializ ...
- C++编程练习(8)----“二叉树的建立以及二叉树的三种遍历方式“(前序遍历、中序遍历、后续遍历)
树 利用顺序存储和链式存储的特点,可以实现树的存储结构的表示,具体表示法有很多种. 1)双亲表示法:在每个结点中,附设一个指示器指示其双亲结点在数组中的位置. 2)孩子表示法:把每个结点的孩子排列起来 ...
- Map三种遍历方式
Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...
- Map的两种遍历方式
********************************************************************************* ****************** ...
- 二叉树总结—建树和4种遍历方式(递归&&非递归)
版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/27967155 今天总结一下二叉树.要考离散了 ...
- iOS开发中数组常用的五种遍历方式
随着iOS的不断发展,apple也不断推出性能更高的数组遍历方式,下面将对熟悉的五种遍历方式进行列举. 首先定义一个数组,并获取数组长度 NSArray *array=@[",]; NSIn ...
- lua中for循环的四种遍历方式
lua中for的四种遍历方式区别 table.maxn 取最大的整数key #table 从1开始的顺序整数最大值,如1,2,3,6 #table == 3 key,value pairs 取每一 ...
- HashMap的两种遍历方式
HashMap的两种遍历方式 HashMap存储的是键值对:key-value . java将HashMap的键值对作为一个整体对象(java.util.Map.Entry)进行处理,这优化了Hash ...
随机推荐
- python 链表、堆、栈
简介 很多开发在开发中并没有过多的关注数据结构,当然我也是,因此,我写这篇文章就是想要带大家了解一下这些分别是什么东西. 链表 概念:数据随机存储,并且通过指针表示数据之间的逻辑关系的存储结构. 链表 ...
- linux学习系列--初识Linux系统
### 认识Linux- Linux是一种类UNIX的系统,Unix是1965年在贝尔实验室开发的一个项目,用来开发操作系统- Linux之父-Linus Torvalds在1991年10月5日,他在 ...
- Python3.7将普通图片(png)转换为SVG图片格式并且让你的网站Logo(图标)从此”动”起来
原文转载自「刘悦的技术博客」https://v3u.cn/a_id_148 在之前的几篇文章中,介绍了业界中比较火爆的图片技术SVG(Scalable Vector Graphics),比如Iconf ...
- Odoo14 需要哪些技术
1 PostgreSQL:数据库,存储数据. 2 Python :主要作用是控制数据库,如:建表.关联字段.批量数据-- 3 html.css.javascript:基础前端. 4 scss:前端样式 ...
- 后端统一处理返回前端日期LocalDateTime格式化去T,Long返回前端损失精度问题
一.前言 我们在实际开发中肯定会遇到后端的时间传到前端是这个样子的:2022-08-02T15:43:50 这个时候前后端就开始踢皮球了,!! 后端说:前端来做就可! 前端说:后端来做就可! 作为一名 ...
- EPLAN中的edz文件的用法
1 EDZ 文件的定义 EDZ 是 EPLAN Data Archive Zipped(EPLAN 数据压缩文件包)的缩写,最早是专门为西门子定制的,现在已经 成为 EPLAN 中一种标准的部件 ...
- 【原创】Python 极验滑块验证
本文仅供学习交流使用,如侵立删! 记一次 极验滑块验证分析并通过 操作环境 win10 . mac Python3.9 selenium.seleniumwire 分析 最近在做的一个项目登录时会触发 ...
- http、https和Cookie
http和https http,https 都是网络传输协议 是用于网络相关传输,http走的是明文传输,https走的密文传输(内部采用对称加密以及非对称加密).对应的https安全性要高于http ...
- Luogu1856 [USACO5.5]矩形周长Picture (线段树扫描线)
对于横轴,加上与上一次扫描的差值:对于竖轴,加上高度差与区间内不相交线段\(*2\)的积: 难点在pushdown,注意维护覆盖关系.再就注意负数 #include <iostream> ...
- TDM 三部曲 (与 Deep Retrieval)
推荐系统的主要目的是从海量物品库中高效检索用户最感兴趣的物品,既然是"海量",意味着用户基本不可能浏览完所有的物品,所以才需要推荐系统来辅助用户高效获取感兴趣的信息.同样也正是因为 ...