二叉树前序遍历查找删除

public class BinaryTree {
	Node root;
	
	public BinaryTree(Node root)
	{
		this.root = root;
	}
	
	public int preDel(int data) {
		if (this.root == null) {
			throw new RuntimeException("空树不能删除");
		}
		if(this.root!= null && this.root.data == data)
		{
			this.root = null;
			return 1;
		}
		return this.root.preDel(data);
	}
	
	public void preOrder() {
		if(this.root != null) 
			this.root.preOrder();
		else {
			System.out.println("此树为空");
		}
	}
	
	public int preFind(int data){
		if (this.root != null) {
			return this.root.preFind(data);
		}
		return -1;
	}
	public int infixFind(int data){
		if (this.root != null) {
			return this.root.infixFind(data);
		}
		return -1;
	}
}

class Node{
	int data;
	Node left;
	Node right;
	
	public Node(int data) {
		this.data = data;
	}
	public int preDel(int data) {
		if(this.left != null && this.left.data == data) {
			
			this.left = null;
			return 1;
		}
		if(this.right != null && this.right.data == data)
		{
			
			this.right = null;
			return 1;
		}
		if(this.left != null)
		{
			int result = this.left.preDel(data);
			if(result == 1)
				return result;
		}
		if(this.right != null)
		{
			return this.right.preDel(data);
		}
		return -1;
	}
	public void preOrder() {
		System.out.println("进入前序遍历");
		System.out.println(this.data);
		if(this.left != null)
			this.left.preOrder();
		if(this.right != null)
			this.right.preOrder();
	}
	
	public int infixFind(int data) {
		if (this.left != null) {
			
			int result = this.left.infixFind(data);
			if(result == 1)
				return result;
		}
		
		System.out.println("进入中序查找" + this);
		if (this.data == data) {
			return 1;
		}
		
		if (this.right != null) {
			
			return this.right.infixFind(data);
		}
		return -1;
	}
	
	public int preFind(int data) {
		
		System.out.println("进入前序查找" + this);
		if (this.data == data) {
			return 1;
		}
		if (this.left != null) {
			
			int result = this.left.preFind(data);
			if(result == 1)
				return result;
		}
		if (this.right != null) {
			
			return this.right.preFind(data);
		}
		return -1;
		
	}

	@Override
	public String toString() {
		return "Node [data=" + data + "]";
	}
	
	
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值