java 二叉树遍历

 

 

 

 

 

import java.util.LinkedList;
import java.util.List;

/**
 * @author baoyou E-mail:curiousby@163.com
 * @version 创建时间:2015年9月7日 上午11:09:36 des:
 */
class BinaryTree { // 定义二叉树的操作类

	static int[] arr= {0,1,2,3,4,5,6,7,8,9}; 
	
	private static class Node {
    	Node left;
    	Node right;
    	int data;
    
    	Node(int data){
    		this.left = null;
    		this.right = null;
    		this.data = data;
    	}
    }
	
   public static void preTraverse(Node node){
	   if (node == null) return;
    	System.out.print(" "+node.data);
    	preTraverse(node.left);
    	preTraverse(node.right);
    }
    
   public static void midTraverse(Node node){
    	if (node == null) return;
    	midTraverse(node.left); 
    	System.out.print(" "+node.data);
    	midTraverse(node.right);
    }
    
   public static void nextTraverse(Node node){
    	if (node == null) return;
    	nextTraverse(node.left);
    	nextTraverse(node.right); 
    	System.out.print(" "+ node.data);
    }
    
   public static Node loading(int[] arr){
	  
	   List <Node> lnode = new LinkedList<Node>();
	   for (int i = 0; i < arr.length; i++) {
		lnode.add(new Node(arr[i]));
	   } 
	   
	   for (int i = 0; i < lnode.size() / 2  ; i++) {
		lnode.get(i).left = 2*i+1 < lnode.size() ?  lnode.get(2*i+1) : null ;
		lnode.get(i).right = 2*i+2 < lnode.size() ?  lnode.get(2*i+2) : null ;
		
	   }
	   
	   return lnode.get(0);
   }
   
   public static void main(String[] args) {
	   Node root = loading(arr);
	   
	   System.out.println("\r\n 前序遍历 二叉树");
	   preTraverse(root);
	   
	   System.out.println("\r\n 中序遍历 二叉树");
	   midTraverse(root);
	   
	   System.out.println("\r\n 后序遍历 二叉树");
	   nextTraverse(root);
   }
} 

 

 

 

 



 



 

 

 

 

 

 

 

 

 

 

 

 

 

 

捐助开发者

在兴趣的驱动下,写一个免费的东西,有欣喜,也还有汗水,希望你喜欢我的作品,同时也能支持一下。 当然,有钱捧个钱场(右上角的爱心标志,支持支付宝和PayPal捐助),没钱捧个人场,谢谢各位。



 
 
 谢谢您的赞助,我会做的更好!

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值