二叉树问题:递归方式实现二叉树先序中序后序遍历

Posted heibingtai

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了二叉树问题:递归方式实现二叉树先序中序后序遍历相关的知识,希望对你有一定的参考价值。

 

问题描述:

用递归方式实现二叉树的先序、中序、后序遍历。

 

算法实现:

//二叉树节点
private class Node {


public int value;
public Node left;
public Node right;

public Node(int value) {
this.value = value;
}
}


//前序遍历
public void preOrderRecur(Node head) {

if (head == null) {
return;
}
System.out.println("output value = " + head.value);
preOrderRecur(head.left);
preOrderRecur(head.right);
}

//中序遍历
public void inOrderRecur(Node head) {

if(head == null) {
return;
}
inOrderRecur(head.left);
System.out.println("output value = " + head.value);
inOrderRecur(head.right);
}

//后序遍历
public void postOrderRecur(Node head) {

if(head == null) {
return;
}
postOrderRecur(head.left);
postOrderRecur(head.right);
System.out.println("output value = " + head.value);
}

 

算法解析:

1.首先要从数据结构的角度,理解二叉树的先序、中序、后序遍历的遍历方式;

2.使用递归方式,要明确终止条件;

3.找到递归抽象的规律,明确三种遍历方式节点打印节点的时机。

 

以上是关于二叉树问题:递归方式实现二叉树先序中序后序遍历的主要内容,如果未能解决你的问题,请参考以下文章

二叉树先序中序后序遍历 递归与非递归 Python实现

二叉树先序中序后序遍历 递归与非递归 Python实现

二叉树先序中序后序遍历的非递归实现

用递归算法先序中序后序遍历二叉树

二叉树先序中序后序的递归及非递归遍历

二叉树遍历(先序中序后序)