完成顺序存储二叉树的前序、中序、后续遍历。
一、代码
public class ArrayBinaryTreeDemo {
public static void main(String[] args) {
int[] arr = { 1, 2, 3, 4, 5, 6, 7 };
ArrayBinaryTree arrayBinaryTree = new ArrayBinaryTree(arr);
System.out.println("前序遍历");
arrayBinaryTree.preOrder();
System.out.println("中序遍历:");
arrayBinaryTree.infixOrder(0);
System.out.println("后序遍历:");
arrayBinaryTree.postOrder(0);
}
}
class ArrayBinaryTree {
private int[] arr;
public ArrayBinaryTree(int[] arr) {
this.arr = arr;
}
public void preOrder() {
this.preOrder(0);
}
public void preOrder(int index) {
if (arr == null || arr.length == 0) {
System.out.println("数组为空,不能完成二叉树的前序遍历");
}
System.out.println(arr[index]);
if ((2 * index + 1) < arr.length) {
preOrder(2 * index + 1);
}
if ((2 * index + 2) < arr.length) {
preOrder(2 * index + 2);
}
}
public void infixOrder(int index) {
if (arr == null || arr.length == 0) {
System.out.println("数组为空,不能完成中序遍历");
}
if ((2 * index + 1) < arr.length) {
infixOrder(2 * index + 1);
}
System.out.println(arr[index]);
if((2 * index + 2) < arr.length) {
infixOrder(2 * index + 2);
}
}
public void postOrder(int index) {
if(arr == null || arr.length == 0) {
System.out.println("数组为空,不能完成后续遍历");
}
if((2 * index + 1) < arr.length) {
postOrder(2 * index + 1);
}
if((2 * index + 2) < arr.length) {
postOrder(2 * index + 2);
}
System.out.println(arr[index]);
}
}
二、结果
前序遍历
1
2
4
5
3
6
7
中序遍历:
4
2
5
1
6
3
7
后序遍历:
4
5
2
6
7
3
1