java 树 前序遍历_Java实现树的遍历(前序、中序、后续(递归|非递归)、层次)...

package com.zeph.bp;

import java.util.LinkedList;

import java.util.Queue;

import java.util.Stack;

public class Tree {

private BinaryTreeNode root;

// 递归中序遍历

public void inOrder(BinaryTreeNode current) {

if (current != null) {

inOrder(current.llink);

System.out.print(current.info);

inOrder(current.rlink);

}

}

// 非递归中序遍历

public void nonRecursiveInOrder() {

Stack stack = new Stack();

BinaryTreeNode current;

current = root;

while ((current != null) || (!stack.empty())) {

if (current != null) {

stack.push(current);

current = current.llink;

} else {

current = (BinaryTreeNode) stack.peek();

stack.pop();

System.out.print(current.info);

current = current.rlink;

}

}

}

// 递归前序遍历

public void preOrder(BinaryTreeNode current) {

if (current != null) {

System.out.print(current.info);

preOrder(current.llink);

preOrder(current.rlink);

}

}

// 非递归前序遍历

public void nonRecursivePreOrder() {

Stack stack = new Stack();

BinaryTreeNode current;

current = root;

while ((current != null) || (!stack.isEmpty())) {

if (current != null) {

System.out.print(current.info);

stack.push(current);

current = current.llink;

} else {

current = (BinaryTreeNode) stack.peek();

stack.pop();

current = current.rlink;

}

}

}

// 递归后序遍历

public void postOrder(BinaryTreeNode current) {

if (current != null) {

postOrder(current.llink);

postOrder(current.rlink);

System.out.print(current.info);

}

}

// 非递归后序遍历

public void notRecursivePostOrder() {

Stack stack = new Stack();

BinaryTreeNode current;

current = root;

while ((current != null) || (!stack.isEmpty())) {

if (current != null) {

current.isFirst = true;

stack.push(current);

current = current.llink;

} else {

current = stack.peek();

stack.pop();

if (current.isFirst) {

current.isFirst = false;

stack.push(current);

current = current.rlink;

} else {

System.out.print(current.info);

current = null;

}

}

}

}

// 树的层次遍历

public void bfs() {

Queue queue = new LinkedList();

BinaryTreeNode current;

current = root;

while ((current != null) || (!queue.isEmpty())) {

if (current != null) {

System.out.print(current.info);

queue.add(current.llink);

queue.add(current.rlink);

current = queue.poll();

} else {

current = queue.poll();

}

}

}

public class BinaryTreeNode {

private BinaryTreeNode llink = null;

private BinaryTreeNode rlink = null;

private int info;

private boolean isFirst;

public BinaryTreeNode(int info) {

this.info = info;

}

}

public void initTree() {

root = new BinaryTreeNode(1);

root.llink = new BinaryTreeNode(2);

root.rlink = new BinaryTreeNode(3);

root.llink.llink = null;

root.llink.rlink = new BinaryTreeNode(4);

}

public BinaryTreeNode getRoot() {

return root;

}

public void setRoot(BinaryTreeNode root) {

this.root = root;

}

public static void main(String[] args) {

Tree tree = new Tree();

tree.initTree();

// tree.preOrder(tree.getRoot());

// tree.nonRecursivePreOrder();

// tree.inOrder(tree.getRoot());

// tree.nonRecursiveInOrder();

// tree.postOrder(tree.getRoot());

// tree.notRecursivePostOrder();

tree.bfs();

}

}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值