java 二叉树遍历

简介:           import java.util.LinkedList; import java.util.List; /** * @author baoyou E-mail:curiousby@163.

 

 

 

 

 

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捐助),没钱捧个人场,谢谢各位。



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

 

 

目录
相关文章
|
3月前
|
存储 Java
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
Java学习笔记 List集合的定义、集合的遍历、迭代器的使用
|
18天前
|
存储 Java 开发者
在 Java 中,如何遍历一个 Set 集合?
【10月更文挑战第30天】开发者可以根据具体的需求和代码风格选择合适的遍历方式。增强for循环简洁直观,适用于大多数简单的遍历场景;迭代器则更加灵活,可在遍历过程中进行更多复杂的操作;而Lambda表达式和`forEach`方法则提供了一种更简洁的函数式编程风格的遍历方式。
|
29天前
|
Java 程序员 编译器
Java|如何正确地在遍历 List 时删除元素
从源码分析如何正确地在遍历 List 时删除元素。为什么有的写法会导致异常,而另一些不会。
24 3
|
1月前
|
前端开发 小程序 Java
java基础:map遍历使用;java使用 Patten 和Matches 进行正则匹配;后端传到前端展示图片三种情况,并保存到手机
这篇文章介绍了Java中Map的遍历方法、使用Pattern和matches进行正则表达式匹配,以及后端向前端传输图片并保存到手机的三种情况。
21 1
|
1月前
|
存储 算法 Java
Java一分钟之-数组的创建与遍历
数组作为Java中存储和操作一组相同类型数据的基本结构,其创建和遍历是编程基础中的基础。通过不同的创建方式,可以根据实际需求灵活地初始化数组。而选择合适的遍历方法,则可以提高代码的可读性和效率。掌握这些基本技能,对于深入学习Java乃至其他编程语言的数据结构和算法都是至关重要的。
29 6
|
1月前
|
Java
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(二)
28 1
|
1月前
|
算法 Java C语言
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
【用Java学习数据结构系列】震惊,二叉树原来是要这么学习的(一)
25 1
|
28天前
|
算法 Java
JAVA 二叉树面试题
JAVA 二叉树面试题
17 0
|
2月前
|
域名解析 分布式计算 网络协议
java遍历hdfs路径信息,报错EOFException
java遍历hdfs路径信息,报错EOFException
38 3
|
3月前
|
Java 容器
07 Java数组与数组操作(定义+遍历+排序+增删改查)(上)
07 Java数组与数组操作(定义+遍历+排序+增删改查)
53 8
下一篇
无影云桌面