数据结构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.节点颜色要 ...
随机推荐
- 【开发工具】- Xshell工具的下载和安装
下载地址:https://www.netsarang.com/zh/free-for-home-school/ Xshell 是一个强大的安全终端模拟软件,它支持SSH1, SSH2, 以及Micro ...
- Wenaox 一款轻量性能好的微信小程序状态管理库
感慨一下!!! 从开始开发 wenaox 从开始到现在,,时不时更新一下,改一改 bug,却发现已经快 1 年了 orz 虽然很少人用 hhh,但偶尔也会有人提一些问题,我就知道还有人用的~ 感兴趣的 ...
- python selenium八大定位方法
一.定位方法 注意:元素属性必须唯一存在 #id定位 find_element_by_id() #name定位 find_element_by_name() #class_name定位 find_el ...
- 碰到的TypeError--记录
TypeError: object of type 'Response' has no len() 我在写爬虫的时候,通过requests获取到了网址的html文件,一开始是用content保存下 ...
- kubernetes-使用kubeadm添加node节点
node节点服务器需要安装好 kubeadm, kubelet 和 kubectl: 使用kubeadm join 命令即行,使用master节点kebeadm init时的提示: root@boke ...
- S3cmd
一:安装方法 #wget http://nchc.dl.sourceforge.net/project/s3tools/s3cmd/1.0.0/s3cmd-1.0.0.tar.gz #tar -zxf ...
- 《你们都是魔鬼吗》第八次团队作业:第四天Alpha冲刺
<你们都是魔鬼吗>第八次团队作业:Alpha冲刺 项目 内容 这个作业属于哪个课程 任课教师博客主页链接 这个作业的要求在哪里 作业链接地址 团队名称 你们都是魔鬼吗 作业学习目标 完成最 ...
- 《hello-world》第九次团队作业:【Beta】Scrum meeting 3
项目 内容 这个作业属于哪个课程 2016级计算机科学与工程学院软件工程(西北师范大学) 这个作业的要求在哪里 实验十三 团队作业9:Beta冲刺与团队项目验收 团队名称 <hello--wor ...
- docker 进程 转载:https://www.cnblogs.com/ilinuxer/p/6188303.html
今天我们会分析Docker中进程管理的一些细节,并介绍一些常见问题的解决方法和注意事项. 容器的PID namespace(名空间) 在Docker中,进程管理的基础就是Linux内核中的PID名空间 ...
- navicat连接oracle报错:ORA-12737 Instant Client Light:unsupported server character set ZHS16GBK
今天使用Navicat连接Oracle数据库,报了下面的这个错误:“ORA-12737 Instant Client Light:unsupported server character set ZH ...