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);
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值