二叉树概念:

  1. 二叉树是每个节点的度均不超过2的有序树,因此二叉树中每个节点的孩子只能是0,1或者2个,并且每个孩子都有左右之分。
  2. 位于左边的孩子称为左孩子,位于右边的孩子成为右孩子;以左孩子为根节点的子树称其为左子树,右孩子为根节点的子树成为右子树。
  3. 二叉树可以使用顺序表(数组)来存储其节点,并且节点的存储位置即为数组的下标索引。

遍历:将二叉树中的节点信息由非线性排列变为某种意义上的线性排列,即遍历操作是非线性结构线性化。

结构如图所示:

三种遍历方式:

  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)的更多相关文章

  1. 基于Java的二叉树的三种遍历方式的递归与非递归实现

    二叉树的遍历方式包括前序遍历.中序遍历和后序遍历,其实现方式包括递归实现和非递归实现. 前序遍历:根节点 | 左子树 | 右子树 中序遍历:左子树 | 根节点 | 右子树 后序遍历:左子树 | 右子树 ...

  2. HashMap概述及其三种遍历方式

    一.HashMap概述: 1.HashMap是一个散列表,它存储的是键值对(key-value)映射: 2.HashMap继承AbstractMap,实现了Map,Cloneable,Serializ ...

  3. C++编程练习(8)----“二叉树的建立以及二叉树的三种遍历方式“(前序遍历、中序遍历、后续遍历)

    树 利用顺序存储和链式存储的特点,可以实现树的存储结构的表示,具体表示法有很多种. 1)双亲表示法:在每个结点中,附设一个指示器指示其双亲结点在数组中的位置. 2)孩子表示法:把每个结点的孩子排列起来 ...

  4. Map三种遍历方式

    Map三种遍历方式 package decorator; import java.util.Collection; import java.util.HashMap; import java.util ...

  5. Map的两种遍历方式

    ********************************************************************************* ****************** ...

  6. 二叉树总结—建树和4种遍历方式(递归&&非递归)

    版权声明:本文为博主原创文章,未经博主同意不得转载. https://blog.csdn.net/u013497151/article/details/27967155 今天总结一下二叉树.要考离散了 ...

  7. iOS开发中数组常用的五种遍历方式

    随着iOS的不断发展,apple也不断推出性能更高的数组遍历方式,下面将对熟悉的五种遍历方式进行列举. 首先定义一个数组,并获取数组长度 NSArray *array=@[",]; NSIn ...

  8. lua中for循环的四种遍历方式

    lua中for的四种遍历方式区别 table.maxn 取最大的整数key #table 从1开始的顺序整数最大值,如1,2,3,6 #table == 3   key,value pairs 取每一 ...

  9. HashMap的两种遍历方式

    HashMap的两种遍历方式 HashMap存储的是键值对:key-value . java将HashMap的键值对作为一个整体对象(java.util.Map.Entry)进行处理,这优化了Hash ...

随机推荐

  1. c语言中的gets和fgets的使用差别

    gets和fgets的差别 2022年6月30日 #include<stdio.h> #include<string.h> #define STLEN 8 int main(i ...

  2. InnoDB 中不同SQL语句设置的锁

    锁定读.UPDATE 或 DELETE 通常会给在SQL语句处理过程扫描到的每个索引记录上设置记录锁.语句中是否存在排除该行的WHERE条件并不重要.InnoDB不记得确切的WHERE条件,但只知道哪 ...

  3. 从零开始Blazor Server(8)--增加菜单以及调整位置

    这篇干啥 这篇文章主要是把前面的一些东西稍微调整一下,使其更适合后面的内容. 主要是两个事,一个是把原来的PermissionEntity直接变成MenuEntity,直接让最后一级是菜单,这样后面就 ...

  4. 强大博客搭建全过程(1)-hexo博客搭建保姆级教程

    1. 前言 本人本来使用国内的开源项目solo搭建了博客,但感觉1核CPU2G内存的服务器,还是稍微有点重,包括服务器内还搭建了数据库.如果自己开发然后搭建,耗费时间又比较多,于是乎开始寻找轻量型的博 ...

  5. Windows 查看端口占用并关闭

    在启动服务的时候,可能会遇到端口被占用的情况. 这时候就需要知道哪个服务占用了这个端口,并将其关闭. 然后再启动服务就不会存在端口占用了. 这里以 Tomcat 的默认端口 8080 为例. 打开命令 ...

  6. Spring源码 05 IOC 注解方式

    参考源 https://www.bilibili.com/video/BV1tR4y1F75R?spm_id_from=333.337.search-card.all.click https://ww ...

  7. 若依 | 点击顶部 tag 标签不自动刷新

    需求场景 之前:只要点击若依顶部的标签,页面都会自动刷新. 问题:A 页面有查询结果,切换到 B 页面查看信息,再切回 A 页面,则 A 页面的查询结果不会保留. 需求:点击标签,页面不自动刷新,或者 ...

  8. 简单理解 Webpack,以及Web前端使用打包工具的原因

    Java 中的模块 传统的前端开发就是 JS.HTML.CSS 三件套.Web 没有像 Java 一样拥有优秀的模块机制,就是类与类之间可以分装在不同的包下,不同包下的类互相引用时通过import导入 ...

  9. github action 实现CI/CD

    两种github action 打包.Net Core 项目docker镜像推送到阿里云镜像仓库 1.GitHub Actions 是什么? 大家知道,持续集成由很多操作组成,比如抓取代码.运行测试. ...

  10. 对Github指定类目的内容进行监控和推送

    很久之前看到HACK学习呀有一个Github 安全搬运工的系列文章,个人觉得很不错,想要在自己的公众号上也做这方面的内容,内容的编辑排版相对来说比较容易,这样问题就回归到Github安全内容的获取上 ...