java二叉树

本文深入探讨了二叉树的数据结构,包括节点定义、插入、查找、遍历(前序、中序、后序)及节点删除等核心操作。通过具体代码实现,详细解析了二叉树的构建与维护过程。
//节点类
class Node1{
	public Node1 leftchild;//左子节点
	public Node1 rightchild;//右子节点
	public int data;
	public String font;
	public Node1(int value,String text){
		data=value;
		font=text;
	}
   
}
//二叉树
class Tree{
 public Node1 root;
  
  public void insert(int value,String text){
	  Node1 node=new Node1(value,text);
	  Node1 current =root;
	  Node1 parent;
	  if(root==null){
		  root=node;
	  }else{
		  while(true){
		  parent=current;
		  if(current.data>value){
			  current=current.leftchild;
		  
			 if(current==null){
				 parent.leftchild=node;
				 return;
			 }
		  }else{
			  current=current.rightchild;
			  if(current==null){
				  parent.rightchild=node;
				  return;
			  }
		  }
  }
		  }
	  }
 //查找 
  public void find(int value){
	  Node1 current=root;
	  while(current.data!=value){
		  if(current.data>value){
			  current=current.leftchild;
		  }else{
			  current=current.rightchild;
		  }
		  if(current==null){
			  System.out.println("找不到");
		  }
	  } System.out.println(current.data);
	  
  }
  //前序遍历
  public void front(Node1 localNode){
	  if(localNode!=null){
		  
		  System.out.println(localNode.data+" "+localNode.font);
		  front(localNode.leftchild);
		  front(localNode.rightchild);
	  }
  }
  
  //中序遍历
  public void middle(Node1 localNode){
	  if(localNode!=null){
		  middle(localNode.leftchild);
		  System.out.println(localNode.data+" "+localNode.font);
		  middle(localNode.rightchild);
	  }
  }
  
  //后序遍历
  public void behind(Node1 localNode){
	  if(localNode!=null){
	  behind(localNode.leftchild);
	  behind(localNode.rightchild);
	  System.out.println(localNode.data+" "+localNode.font);
  }
	  }
  
  //删除节点
  public boolean delete(int value){
	  Node1 current=root;
	  Node1 parent=root;
	  boolean isLeftchild=true;
	  while(current.data!=value){
		  parent=current;
		  if(current.data>value){
			  current=current.leftchild;
			  isLeftchild=true;
		  }else if(current.data<value){
			  current=current.rightchild;
			  isLeftchild=false;
		  }if(current==null){
			  return false;
		  }
	  }
	  if(current.leftchild==null&&current.rightchild==null){
		  if(current==root){
			  root=null;
		  }else if(isLeftchild){
			  parent.leftchild=null;
		  }else{
			  parent.rightchild=null;
		  }
	  }else if(current.rightchild==null){
		  if(current==root){
			  root=current.leftchild;
		  }else if(isLeftchild){
			  parent.leftchild=current.leftchild;
		  }else{
			  parent.rightchild=current.leftchild;
		  }
	  }else if(current.leftchild==null){
		  if(isLeftchild){
			  parent.leftchild=current.rightchild;
		  }else{
			  parent.rightchild=current.rightchild;
		  }
	  }else{
		  Node1 success=getsuccess(current);
		  if(current==root){
			  root=success;
		  }else if(isLeftchild){
			  parent.leftchild=success;
		  }else{
			  parent.rightchild=success;
		  }success.leftchild=current.rightchild;
	  }
	  return true;
  }
  
  public Node1 getsuccess(Node1 delnode){
	  Node1 successor=delnode;
	  Node1 successorParent=delnode;
	  Node1 current=delnode.rightchild;
	  while(current!=null){
		  successorParent=successor;
		  successor=current;
		  current=current.leftchild;
	  }
	  if(successor!=delnode.rightchild){
		  successorParent.leftchild=successor.rightchild;
		  successor.rightchild=delnode.rightchild;
		  
	  }return successor;
	  
  }
}

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值