Java构造二叉树及其三种遍历方式


public class Erchashu {
	public static void main(String ards[])
	{
		//创建一颗二叉树
		BinaryTerr binaryTerr=new BinaryTerr();
		HeroNode root=new HeroNode(1, "金海");
		HeroNode node2=new HeroNode(2, "铁林");
		HeroNode node3=new HeroNode(3, "徐天");
		HeroNode node4=new HeroNode(4, "燕三");
		root.setLeft(node2);
		root.setRight(node3);
		node2.setLeft(node4);
		binaryTerr.setRoot(root);
		System.out.println("前序遍历");
		binaryTerr.pre();
		System.out.println("中序遍历");
		binaryTerr.pro();
		System.out.println("后序遍历");
		binaryTerr.prh();
		
		
	}

}
//构造二叉树
class BinaryTerr{
	private HeroNode root;  //生成一个根结点
	public void setRoot(HeroNode root)
	{
		this.root=root;  
	}
	public void pre(){
		if(this.root!=null)
		{
			this.root.pre();
		}
		else{
			System.out.println("二叉树为空不能遍历");
		}
	}
	public void pro(){
		if(this.root!=null)
		{
			this.root.pro();
		}
		else{
			System.out.println("二叉树为空不能遍历");
		}
	}
	public void prh(){
		if(this.root!=null)
		{
			this.root.prh();
		}
		else{
			System.out.println("二叉树为空不能遍历");
		}
	}
}
//创建二叉树结点
class HeroNode{
	private int no;
	private String name;
	private HeroNode left;  //左孩子默认为空
	private HeroNode right; //右孩子默认为空
	public HeroNode(int no,String name)  //构造函数
	{
		
		this.no=no;
		
		this.name=name;
	}

	//给当前结点挂上左孩子
	public void setLeft(HeroNode left) {
		this.left = left;
	}

	//给当前结点挂上右孩子
	public void setRight(HeroNode right) {
		this.right = right;
	}

	
	@Override
	public String toString(){
		return "HeroNode [no="+no+",name="+name+"]";
	}
	//先序遍历
	public void pre(){
		System.out.println(this.toString());
		if(this.left!=null)
		{
			this.left.pre();
		}
		if(this.right!=null)
		{
			this.right.pre();
		}
	}
	public void pro(){
		
		if(this.left!=null)
		{
			this.left.pre();
		}
		System.out.println(this.toString());
		if(this.no==1)
		{
			System.out.println("找到了");
			return;
		}
		if(this.right!=null)
		{
			this.right.pre();
		}
	}
public void prh(){
		
		if(this.left!=null)
		{
			this.left.pre();
		}
		
		if(this.right!=null)
		{
			this.right.pre();
		}
		System.out.println(this.toString());
	}
}


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值