java实现二叉树遍历(先序中序后序)

二叉树的遍历,主要有先序中序和后序遍历,三个的递归实现都比较简单,而非递归实现略复杂。
先遍历之前,我们先定义一个节点

public class TreeNode {
	private int data;
	private TreeNode left;
	private TreeNode right;
	//get set方法省略
}

递归实现

  1. 先序遍历
public void preOrder(TreeNode root){
	if(root!=null){
		System.out.println(root.getData());
		preOrder(root.getLeft());
		preOrder(root.getRight());
	}
}
  1. 中序遍历
public void inOrder(TreeNode root){
	if(root!=null){
		inOrder(root.getLeft());
		System.out.println(root.getData());
		inOrder(root.getRight());
	}
	
}
  1. 后序遍历
public void postOrder(TreeNode root){
	if(root!=null){
		postOrder(root.getLeft());
		postOrder(root.getRight());
		System.out.println(root.getData());
	}
}

非递归实现

  1. 先序遍历
public void preOrder(TreeNode root){
	Stack stack = new Stack();
	while(true){
		while(root!=null){
			System.out.println(root.getData());
			stack.push(root);
			root = root.getLeft();
		}
		if(stack.isEmpty()) break;
		root = stack.pop();
		root = root.getRight();
	}
}
  1. 中序遍历
public void inOrder(TreeNode root){
	Stack stack = new Stack();
	while(true){
		while(root!=null){
			stack.push(root);
			root = root.getLeft();
		}
		if(!stack.isEmpty()) break;
		root = stack.pop();
		System.out.println(root.getData());
		root = root.getRight();
	}
}
  1. 后序遍历(两个栈实现)
public void postOrder(TreeNode root){
	if(root==null) return;
	Stack stack1 = new Stack();
	Stack stack2 = new Stack();
	stack1.push(root);
	while(!stack1.isEmpty()){
		TreeNode node = stack1.pop();
		stack2.push(node);
		if(node.getLeft()!=null){
			stack1.push(node.getLeft());
		}
		if(node.getRight()!=null){
			stack1.push(node.getRight());
		}
	}
	while(!stack2.isEmpty())
		System.out.println(stack2.pop().getData());
	
}

你可能感兴趣的:(算法)