二叉树删除结点

方法一(delNode):若为非叶子结点将此结点的树直接删除(代码163行)

方法二(delNode1):若为非叶子结点(代码188行)
            若只有一个子结点,让该子节点代替结点
            若结点为a,左子结点为b,右子接点为c,让b结点代表a

package tree;

public class BinaryTreeAPP {

	public static void main(String[] args) {
		// TODO 自动生成的方法存根
		HeroNode root=new HeroNode(1, "宋江");
		HeroNode node1=new HeroNode(2, "吴用");
		HeroNode node2=new HeroNode(3, "卢俊义");
		HeroNode node3=new HeroNode(4, "林冲");
		HeroNode node4=new HeroNode(5, "关胜");
		root.setLeft(node1);
		root.setRight(node2);
		node2.setRight(node3);
		node2.setLeft(node4);
		BinaryTree binaryTree=new BinaryTree(root);
		System.out.println("删除结点前:");
		System.out.println("前序排序");
		binaryTree.preOrder();
		System.out.println("中序排序");
		binaryTree.midOrder();
		System.out.println("后序排序");
		binaryTree.postOrder();
		binaryTree.delNode1(3);
		System.out.println("删除结点后:");
		System.out.println("前序排序");
		binaryTree.preOrder();
		System.out.println("中序排序");
		binaryTree.midOrder();
		System.out.println("后序排序");
		binaryTree.postOrder();
	}

}

//树
class BinaryTree{
	private HeroNode root;
	public BinaryTree(HeroNode root) {
		this.root=root;
	}
	
	//调用前序遍历
	public void preOrder() {
		if(root!=null) {
			root.preOrder();
		}else {
			System.out.println("根节点为空 ");
		}
	}
	
	//调用中序遍历
	public void midOrder() {
		if(root!=null) {
			root.midOrder();
		}else {
			System.out.println("根节点为空 ");
		}
	}
	
	//调用后序遍历
	public void postOrder() {
		if(root!=null) {
			root.postOrder();
		}else {
			System.out.println("根节点为空 ");
		}
	}
	
	//调用删除结点方法
	public void delNode(int no) {
		if(root!=null) {
			root.delNode(root, no);
		}else {
			System.out.println("根节点为空 ");
		}
	}
	
	//调用删除节点方法一
	public void delNode1(int no) {
		if(root!=null) {
			root.delNode1(root, no);
		}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.setNo(no);
		this.setName(name);
	}
	public String getName() {
		return name;
	}
	public void setName(String name) {
		this.name = name;
	}
	public HeroNode getLeft() {
		return left;
	}
	public void setLeft(HeroNode left) {
		this.left = left;
	}
	public HeroNode getRight() {
		return right;
	}
	public void setRight(HeroNode right) {
		this.right = right;
	}
	public int getNo() {
		return no;
	}
	public void setNo(int no) {
		this.no = no;
	}
	public void show() {
		System.out.println("HeroNode [no="+no+",name="+name+"]");
	}
	
	//前序遍历
	public void preOrder() {
		this.show();
		if(this.left!=null) {
			this.left.preOrder();
		}
		if(this.right!=null) {
			this.right.preOrder();
		}
	}
	
	//中序遍历
	public void midOrder() {
		if(this.left!=null) {
			this.left.midOrder();
		}
		this.show();
		if(this.right!=null) {
			this.right.midOrder();
		}
	}
	
	//后序遍历
	public void postOrder() {
		if(this.left!=null) {
			this.left.postOrder();
		}
		if(this.right!=null) {
			this.right.postOrder();
		}
		this.show();
	}
	
	//删除结点(若为非叶子结点将此结点的树直接删除)
	public void delNode(HeroNode temp,int flag){
		if(temp.left!=null&&temp.left.no==flag){
			temp.left=null;
			return;
		}
		if(temp.right!=null&&temp.right.no==flag){
			temp.right=null;
			return;
		}
		if(temp.left!=null){
			delNode(temp.left,flag);
		}
		if(temp.right!=null){
			delNode(temp.right,flag);
		}

		System.out.println("未找到此结点");
	}



	//删除结点(若为非叶子结点)
	//若只有一个子结点,让该子节点代替结点
	//若结点为a,左子结点为b,右子接点为c,让b结点代表a
	//node:待删除结点的父节点
	public void delNode1(HeroNode node,int flag){
		if(node.left!=null&&node.left.no==flag){//匹配成功
			HeroNode temp=node.left;//temp承载被删除结点
			if(temp.left==null&&temp.right==null){//叶子结点
				node.left=null;//叶子节点直接删除
			}else if(temp.left!=null&&temp.right!=null){//两个子节点
				temp.left.right=temp.right;//将被删除结点的左子节点的右子节点指向被删除结点子节点的右子节点
				node.left=temp.left;//被删除结点的父节点的左子节点指向被删除节点的左子节点(被删除字节的左子节点取代被删除节点的位置)
			}else if(temp.left!=null&&temp.right==null){//右子结点为空
				node.left=temp.left;
			}else if(temp.right!=null&&temp.left==null){//左子结点为空
				node.left=temp.right;
			}
			return;
		}
		if(node.right!=null&&node.right.no==flag){//匹配成功
			HeroNode temp=node.right;
			if(temp.left==null&&temp.right==null){//叶子结点
				node.right=null;
			}else if(temp.left!=null&&temp.right!=null){//两个子节点
				node.right=temp.left;
				temp.left.left=temp.right;
			}else if(temp.left!=null&&temp.right==null){//右子结点为空
				node.right=temp.left;
			}else if(temp.right!=null&&temp.left==null){//左子结点为空
				node.right=temp.right;
			}
			return;
		}
		if(node.left!=null){
			delNode(node.left,flag);
		}
		if(node.right!=null){
			delNode(node.right,flag);
		}
		System.out.println("未找到该结点");
	}
}

删除前:

 

方法一: 

 

 

 方法二:

 

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值