java实现树的前序,后序,中序的非递归遍历

树的初始化:(自己根据代码树的初始化画一个二叉树)

代码中的树的前序遍历:0 4 2 1 3 5 6 7 

中序遍历:1 2 4 3 0 6 5 7

后序遍历:1 2 3 4 6 7 5 0


代码:


package Tree;

import Stack.Stack;


public class Demo2 {

	//树的非递归的前序,中序,后序的遍历
	public static void main(String[] args) {
		
		Tree t1 = new Tree(1,null,null);
		Tree t2 = new Tree(2, t1, null);
		Tree t3 = new Tree(3, null, null);
		Tree t4 = new Tree(4, t2, t3);
		
		Tree t51 = new Tree(6,null,null);
		Tree t52 = new Tree(7, null, null);
		Tree t5 = new Tree(5, t51, t52);
		Tree t6 = new Tree(0, t4, t5);
		
		System.out.println("前序遍历(非递归)");
		Demo2.PretraverseS(t6);
		System.out.println();
		System.out.println("中序遍历(非递归)");
		Demo2.IntraverseS(t6);
		System.out.println();
		System.out.println("后续遍历(非递归):");
		Demo2.PostraverseS(t6);
	}
	
	
	//前序遍历(非递归)
	public static void PretraverseS(Tree h){
		if(h==null)return;
		Stack stack = new Stack();
		stack.push(h);
		while(!stack.isEmpty()){
			h = (Tree) stack.pop();
			h.visit();
			if(h.right!=null)stack.push(h.right);
			if(h.left!=null)stack.push(h.left);
		}
	}
	
	//中序遍历(非递归)
	public static void IntraverseS(Tree h){
		if(h==null)return;
		Stack stack = new Stack();
		while(h!=null||!stack.isEmpty()){
			if(h!=null){
				stack.push(h);
				h = h.left;
			}else
			{
				h = (Tree) stack.pop();
				h.visit();
				h = h.right;
			}
		}
	}
	
	//后序遍历(非递归)
	public static void PostraverseS(Tree h){
		if(h==null)return;
		Stack stack = new Stack();
		while(h!=null||!stack.isEmpty()){
			if(h!=null){
				stack.push(h);
				stack.push(1);
				h = h.left;
			}else{
				while(!stack.isEmpty()){
					int sign = (Integer) stack.pop();
					h = (Tree) stack.pop();
					if(sign==1){
						stack.push(h);
						stack.push(2);
						h = h.right;
						break;
					}else{
						h.visit();
						h = null;
					}
				}
			}
		}
	}
	
	public static class Tree{
		int val;
		Tree left;
		Tree right;
		public Tree(int val,Tree left,Tree right){
			this.val = val;
			this.left = left;
			this.right = right;
		}
		public Tree(){}
		public void visit(){
			System.out.print(val+" ");
		}
	}

}



Stack类参考本博客: http://blog.csdn.net/tan313/article/details/39998529

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值