数据结构Java版之遍历二叉树(六)
二叉树是我们在程序中用的最多的一种树(个人观点)。最简单的一个二叉树是由一个根节点,两个子节点(一左一右成左右孩子节点)组成。二叉树是数组和链表的结合,即包含了数组的快速查找优点,又包含了链表的快速添加删除的优点。熟练掌握二叉树的遍历方法是很有必要的。下面来介绍一下基于二叉树的四种遍历方式。
下面我们以一个棵简单的二叉树为例来说明四种遍历:

创建树节点类:
//树节点
class TreeNode {
public char val;
public TreeNode left;
public TreeNode right; public TreeNode(char x) {
val = x;
}
}
中序遍历:
先遍历左孩子节点---根节点---右孩子节点
//中序遍历 左-根-右 (前中后:根的位置)
public void InOrder(TreeNode current){
if(current != null) {
InOrder(current.left);
Visit(current);
InOrder(current.right);
}
}
前序遍历:
遍历根节点---左孩子节点---右孩子节点
//前序遍历 根-左-右
public void PreOrder(TreeNode current){
if(current != null) {
Visit(current);
InOrder(current.left);
InOrder(current.right);
}
}
后序遍历:
遍历左孩子节点---右孩子节点---根节点
//后续遍历 左-右-根
public void PostOrder(TreeNode current){
if(current != null) {
InOrder(current.left);
InOrder(current.right);
Visit(current);
}
}
层序遍历:
同一层节点从左往右依次遍历。
//层序遍历 同一层节点从左往右依次遍历 FIFO
public void LevelOrder(TreeNode current){
List<TreeNode> q = new ArrayList<TreeNode>();
while(current != null) {
Visit(current);
if(current.left != null) {
q.add(current.left);
}
if(current.right != null) {
q.add(current.right);
}
if(q.isEmpty()) return ;
current = q.remove(0);
}
}
以上就是四种基本遍历方式。下面我们来测试一下,首先写一个工具函数,用来显示当前节点的值。
//*********辅助工具****************
public void Visit(TreeNode node) {
System.out.print(node.val);
}
写Test测试函数:
@Test
public void fun() {
TreeNode root = new TreeNode('+');
root.left = new TreeNode('-');
root.right = new TreeNode('E');
root.left.left = new TreeNode('*');
root.left.right = new TreeNode('D');
root.left.left.left = new TreeNode('/');
root.left.left.right = new TreeNode('C');
root.left.left.left.left = new TreeNode('A');
root.left.left.left.right = new TreeNode('B'); System.out.println("中序遍历:");
InOrder(root);
System.out.println();
System.out.println("前序遍历:");
PreOrder(root);
System.out.println();
System.out.println("后序遍历:");
PostOrder(root);
System.out.println();
System.out.println("层序遍历:");
LevelOrder(root);
System.out.println();
}
由上面的测试函数得到遍历结果:

全部代码:
package tree; import java.util.ArrayList;
import java.util.List; import org.junit.Test;
/**
* 二叉数的遍历
* +
* - E
* * D
* / C
* A B
* @author Ranter
*
*/
public class BinaryTree {
@Test
public void fun() {
TreeNode root = new TreeNode('+');
root.left = new TreeNode('-');
root.right = new TreeNode('E');
root.left.left = new TreeNode('*');
root.left.right = new TreeNode('D');
root.left.left.left = new TreeNode('/');
root.left.left.right = new TreeNode('C');
root.left.left.left.left = new TreeNode('A');
root.left.left.left.right = new TreeNode('B'); System.out.println("中序遍历:");
InOrder(root);
System.out.println();
System.out.println("前序遍历:");
PreOrder(root);
System.out.println();
System.out.println("后序遍历:");
PostOrder(root);
System.out.println();
System.out.println("层序遍历:");
LevelOrder(root);
System.out.println();
} //**************************************************************** //中序遍历 左-根-右 (前中后:根的位置)
public void InOrder(TreeNode current){
if(current != null) {
InOrder(current.left);
Visit(current);
InOrder(current.right);
}
}
//前序遍历 根-左-右
public void PreOrder(TreeNode current){
if(current != null) {
Visit(current);
InOrder(current.left);
InOrder(current.right);
}
}
//后续遍历 左-右-根
public void PostOrder(TreeNode current){
if(current != null) {
InOrder(current.left);
InOrder(current.right);
Visit(current);
}
}
//层序遍历 同一层节点从左往右依次遍历(使用队列层序遍历)
public void LevelOrder(TreeNode current){
List<TreeNode> q = new ArrayList<TreeNode>();
while(current != null) {
Visit(current);
if(current.left != null) {
q.add(current.left);
}
if(current.right != null) {
q.add(current.right);
}
if(q.isEmpty()) return ;
current = q.remove(0);
}
} //*********辅助工具****************
public void Visit(TreeNode node) {
System.out.print(node.val);
} //树节点
class TreeNode {
public char val;
public TreeNode left;
public TreeNode right; public TreeNode(char x) {
val = x;
}
}
}
数据结构Java版之遍历二叉树(六)的更多相关文章
- 剑指Offer面试题39(Java版):二叉树的深度
题目:输入一棵二叉树的根节点,求该数的深度. 从根节点到叶结点依次进过的结点(含根,叶结点)形成树的一条路径,最长路径的长度为树的深度. 比如.例如以下图的二叉树的深度为4.由于它从根节点到叶结点的最 ...
- 数据结构Java版之广度优先图(十三)
广度优先,则是用的队列,将每一层的节点先存入队列中去,后依次取出队列中的节点,显示与当前节点存在边,但是未被访问过的节点,也就是下一层与之相联系的节点,再将这些节点存入队列.经过层层迭代,就可以完全遍 ...
- 数据结构Java版之深度优先-图(十二)
这里用深度优先遍历存在矩阵里面的图. 深度优先利用的是栈的FIFO特性.为此遍历到底后,可以找到最相邻的节点继续遍历.实现深度优先,还需要在节点加上一个访问标识,来确定该节点是否已经被访问过了. 源码 ...
- 数据结构Java版之堆&堆排序(九)
堆分为大顶堆,和小顶堆. 什么是堆? 堆可以看成是一棵二叉树,二叉树的元素是一个数组不断的从左到右轮训放置.如果是大顶堆,则大的数放上面一层,小的数放下面一层.上一层的数,一定大于下一层的数.小顶堆则 ...
- 数据结构Java版之交换算法(一)
交换的本质是拷贝,其中拷贝包括两种方式.值拷贝和指针拷贝,在java中没有指针,为此,我们可以理解为地址拷贝,在我看来,指针就是地址. 1.传值方式示例: 由上述示例可得,传值,不能起到交换的作用,原 ...
- 数据结构Java版之基数排序(四)
基数排序: 基数排序分为两种:第一种是LSD ,从最低位开始排序, 第二种是 MSD 从最高位开始排.这里介绍第一种LSD排序算法. 首先,我们先了解什么是基数.基数是根据具体的排序情况而定的,比如我 ...
- 数据结构Java版之邻接矩阵实现图(十一)
邻接矩阵实现图,是用一个矩阵,把矩阵下标作为一个顶点,如果顶点与顶点之间有边.那么在矩阵对应的点上把值设为 1 .(默认是0) package mygraph; import java.util.Li ...
- 数据结构Java版之邻接表实现图(十)
邻接表实现图,实际上是在一个数组里面存放链表,链表存放的是连接当前节点的其他节点. package mygraph; import java.util.ArrayList; import java.u ...
- 数据结构Java版之红黑树(八)
红黑树是一种自动平衡的二叉查找树,因为存在红黑规则,所以有效的防止了二叉树退化成了链表,且查找和删除的速度都很快,时间复杂度为log(n). 什么是红黑规则? 1.根节点必须是黑色的. 2.节点颜色要 ...
随机推荐
- django.core.exceptions.ImproperlyConfigured: SQLite 3.8.3 or later is required (found 3.7.17)
https://blog.csdn.net/qq_39969226/article/details/92218635
- mysql:[Err] 1068 - Multiple primary key defined
添加主键时,出现错误:[Err] 1068 - Multiple primary key defined #增加主键 ) not null; ; alter table my_test add pri ...
- Kubernetes高级调度- Taint和Toleration、Node Affinity分析
此文分享了污点和Node Affinity实际使用过程中的细节.坑和思维误区.同时整理且回答了诸多细节问题,尤其那些在官方文档中不曾提及的细节. 阅读提示:文中的节点指Node (避免Pod和Node ...
- python蟒蛇绘制的代码以及目前还不知道怎么用的RGB颜色对照表
#PythonDraw.py import turtle#引入海龟库 turtle.setup(650,350,200,200)#确定窗口大小,长650,高350,确定窗口位置,距离电脑左上角200, ...
- openGL起飞篇
我的技术路线:glfw+glad(有了glfw,什么glew,freeglut都不要了) GLFW:直接下载,然后新建vs项目,在<VC++>的<包含目录>添加include路 ...
- Java精通并发-notify方法详解及线程获取锁的方式分析
wait(): 在上一次https://www.cnblogs.com/webor2006/p/11404521.html中对于无参数的wait()方法的javadoc进行了解读,而它是调用了一个参数 ...
- python get/post接口使用
背景: 使用python调用get post接口,入参.出参都需要转换,在使用时经常会忘记其中的一步,本文用来记录,后面再使用时直接参考使用 代码如下 post: headers = {'Conten ...
- 任何人都适合的常用Chrome插件(工欲善其事必先利其器)
1.划词翻译 介绍链接:http://t.cn/RqpoGU4 下载地址: Chrome 应用商店(请翻墙). 下载 .crx 安装包手动安装 功能如下: - 支持几乎所有语言的翻译与阅读,并且同时支 ...
- react 学习记录
1. 脚手架搭建项目 create-react-app https://www.jianshu.com/p/d196761c8332 2. UI框架 https://ant.design/docs ...
- go socket 服务端处理多用户
package main import ( "fmt" "net" "strings") func main() { listener, e ...