`
wangtao576
  • 浏览: 14511 次
  • 性别: Icon_minigender_1
  • 来自: 重庆
最近访客 更多访客>>
社区版块
存档分类
最新评论

java实现二叉树遍历

阅读更多
package test;

public class Node {
	protected char key;
	protected Node left,right;
	public Node(){
		left=right=null;
	}
	public Node(char key){
		this(key, null, null);
	}
	public Node(char key,Node left,Node right){
		this.key=key;
		this.left=left;
		this.right=right;
	}

	public char getKey(){
		return this.key;
	}
	public void visit(){
		System.out.print(getKey()+", ");
	}
	public static void preOrderTraverse(Node t){//先序遍历
		t.visit();
		if(t.left!=null)
			preOrderTraverse(t.left);
		if(t.right!=null)
			preOrderTraverse(t.right);
	}
	public static void InOrderTraverse(Node t){//中序遍历
		if(t.left!=null)
			InOrderTraverse(t.left);
		t.visit();
		if(t.right!=null){
			InOrderTraverse(t.right);
		}
	}
	public static void PostOrderTraverse(Node t){//后序遍历
		if(t.left!=null)
			PostOrderTraverse(t.left);
		if(t.right!=null)
			PostOrderTraverse(t.right);
		t.visit();
	}
	public static void main(String[] args){
			Node g=new Node('g');
			Node e=new Node('e');
			Node f=new Node('f');
			Node d=new Node('d',g,null);
			Node b=new Node('b',null,d);
			Node c=new Node('c',e,f);
			Node a=new Node('a',b,c);
			System.out.print("PreOrderTraverse: ");
			Node.preOrderTraverse(a);
			System.out.println();
			System.out.print("InOrderTraverse: ");
			Node.InOrderTraverse(a);
			System.out.println();
			System.out.print("PostOrderTraverse: ");
			Node.PostOrderTraverse(a);
	}
}
分享到:
评论

相关推荐

Global site tag (gtag.js) - Google Analytics