排序二叉树-删除节点

排序二叉树-删除节点前面(https://blog.csdn.net/jsjsjs1789/article/details/106772632),我们已经了解了什么是排序二叉树以及排序二叉树的遍历和添加元素,现在我们一起来看一下,排序二叉树是如何删除元素的。packagexmht.datastructuresandalgorithms.datastructure.binarysortTree;/***@authorshengjk1*@date2020/6/15*/publicclassB

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

前面( https://blog.csdn.net/jsjsjs1789/article/details/106772632 ),我们已经了解了什么是排序二叉树以及排序二叉树的遍历和添加元素,现在我们一起来看一下,排序二叉树是如何删除元素的。

步骤
先找到要删除的节点 targetNode
找到要删除节点的父节点 parent
一、删除叶子节点
1.确定 targetNoe 是 parent 的左子节点还是右子节点
2.根据前面的情况来对应删除
parent.left=null.
parent.right=null
二、删除只有一颗子树的节点
1.确定 targetNode 的子节点是右子节点还是左子节点
2.确定 targetNode 是 parent 的左子节点还是右子节点
3.对应删除
三、删除有两颗子树的节点
1.从 targetNode 的右子树找到最小的节点
2.用一个临时变量,将最小节点的值保存 temp
3.删除最小节点
4.targetNode.value=temp
代码
package xmht.datastructuresandalgorithms.datastructure.binarysortTree;

/** * @author shengjk1 * @date 2020/6/15 */
public class BinarySortTree { 
   
	public static void main(String[] args) { 
   
		int[] arr = { 
   7, 3, 10, 12, 5, -1, 9};
		BinarySortTree1 binarySortTree = new BinarySortTree1();
		for (int i : arr) { 
   
			binarySortTree.add(new Node(i));
		}
		
		System.out.println("中序遍历二叉树");
		binarySortTree.infixOrder();
		
		binarySortTree.delNode(3);
		
		System.out.println("删除之后====中序遍历二叉树");
		binarySortTree.infixOrder();
	}
}

class BinarySortTree1 { 
   
	//
	private Node root;
	
	public void add(Node node) { 
   
		if (this.root != null) { 
   
			this.root.add(node);
		} else { 
   
			root = node;
		}
	}
	
	//查找节点
	public Node search(int value) { 
   
		if (root == null) { 
   
			return null;
		} else { 
   
			return root.search(value);
		}
	}
	
	//查找父节点
	public Node searchParent(int value) { 
   
		if (root == null) { 
   
			return null;
		} else { 
   
			return root.searchParent(value);
		}
	}
	
	/** * 返回以 node 为根节点的二叉排序树的最小节点的值 * 并删除以 node 为根节点的二叉排序树的最小节点 * * @param node 传入节点 * @return 以 node 为根节点的二叉排序树的最小节点的值 */
	public int delRightTreeMin(Node node) { 
   
		Node target = node;
		while (target.left != null) { 
   
			target = target.left;
		}
		delNode(target.value);
		return target.value;
		
	}
	
	//删除节点
	public void delNode(int value) { 
   
		if (root == null) { 
   
			return;
		} else { 
   
			//1.先找到要删除节点 targetNode
			Node targetNode = root.search(value);
			if (targetNode == null) { 
   
				return;
			}
			//如果发现当前的二叉树只有一个节点
			if (root.left == null && root.right == null) { 
   
				root = null;
				return;
			}
			
			//找到 targetNode 的 parentnode
			Node parentNode = searchParent(value);
			
			//1.如果删除的节点是叶子节点
			if (targetNode.right == null && targetNode.left == null) { 
   
				if (parentNode.left != null && parentNode.left.value == value) { 
   
					parentNode.left = null;
				} else { 
   
					parentNode.right = null;
				}
				//删除有两颗子树的节点
			} else if (targetNode.left != null && targetNode.right != null) { 
   
				int minVal = delRightTreeMin(targetNode.right);
				targetNode.value = minVal;
				//删除只有一颗子树的节点
			} else { 
   
				//如果删除的节点只有左子树
				if (targetNode.left != null) { 
   
					if (parentNode != null) { 
   
						if (parentNode.left.value == value) { 
   
							parentNode.left = targetNode.left;
							//targetNode 为 parent 的右节点
						} else { 
   
							parentNode.right = targetNode.left;
						}
					} else { 
   
						root = targetNode.left;
					}
				} else { 
   
					if (parentNode != null) { 
   
						if (parentNode.left.value == value) { 
   
							parentNode.left = targetNode.right;
						} else { 
   
							parentNode.right = targetNode.right;
						}
					} else { 
   
						root = targetNode.right;
					}
				}
			}
		}
	}
	
	public void infixOrder() { 
   
		if (this.root != null) { 
   
			this.root.infixOrder();
		}
	}
	
	@Override
	public String toString() { 
   
		return "BinarySortTree1{" +
				"root=" + root +
				'}';
	}
}

class Node { 
   
	int value;
	Node left;
	Node right;
	
	public Node(int value) { 
   
		this.value = value;
	}
	
	
	/** * @param value 希望删除节点的值 * @return 有则返回否则返回null */
	public Node search(int value) { 
   
		if (value == this.value) { 
   
			return this;
			//向左子树查找
		} else if (value < this.value) { 
   
			if (this.left == null) { 
   
				return null;
			}
			return this.left.search(value);
			
			//向右子树查找
		} else { 
   
			if (this.right == null) { 
   
				return null;
			}
			return this.right.search(value);
		}
	}
	
	//查找要删除节点的父节点
	
	/** * @param value * @return */
	public Node searchParent(int value) { 
   
		//如果当前节点就是要删除节点的父节点,就返回
		if ((this.left != null && this.left.value == value) ||
				(this.right != null && this.right.value == value)) { 
   
			return this;
		} else { 
   
			if (value < this.value && this.left != null) { 
   
				return this.left.searchParent(value);
			} else if (value >= this.value && this.right != null) { 
   
				return this.right.searchParent(value);
			} else { 
   
				return null;
			}
		}
	}
	
	//添加节点
	//递归的形式添加,需要满足二叉排序树的要求
	public void add(Node node) { 
   
		if (node == null) { 
   
			return;
		}
		//判断传入节点的值,和当前子树的根节点的值的关系
		if (node.value < this.value) { 
   
			if (this.left == null) { 
   
				this.left = node;
			} else { 
   
				//递归的向左子树添加
				this.left.add(node);
			}
		} else { 
   
			if (this.right == null) { 
   
				this.right = node;
			} else { 
   
				this.right.add(node);
			}
		}
	}
	
	//中序遍历
	public void infixOrder() { 
   
		if (this.left != null) { 
   
			this.left.infixOrder();
		}
		System.out.println(this);
		
		if (this.right != null) { 
   
			this.right.infixOrder();
		}
	}
	
	
	@Override
	public String toString() { 
   
		return "Node{" +
				"value=" + value +
				'}';
	}
}
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/160042.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Mac安装 yarn

    Mac安装 yarnMac安装yarnMac安装yarn一、按照提示安装gcc二、解决gcc错误的方法三、安装yarn四、配置VPN后,再次安装yarn五、下载yarn的tar.gz包,进行离线安装。Mac安装yarnMac升级到10.15.4之后,Xcode也升级到Version11.4.1(11E503a),终端下执行brewinstallyarn进行yarn安装,最后报错gcc错误。…

    2022年5月9日
    727
  • 一些有用的网站(长期记录)「建议收藏」

    一些有用的网站(长期记录)「建议收藏」1.PPT超级市场(完全免费的 PPT 模板下载网站)http://ppt.sotary.com/web/wxapp/index.html2.熊猫搜书https://ebook.huzerui.com/3.秘塔写作猫(AI智能写作工具)xiezuocat.com/4.联图云光盘(收录了很多的光盘资料的在线学习网站)http://discx.yuntu.io/5.GitMind完全免费的在线思维导图制作网站https://gitmind.cn/6.简答题(搜题)

    2022年8月18日
    3
  • Wallpaper Engine 占用GPU过高解决办法「建议收藏」

    Wallpaper Engine 占用GPU过高解决办法「建议收藏」看到本文的时候,首先你要有一个大致认识:Wallpaper中的壁纸大致分为两种:一种是实时计算渲染的,一种是视频播放渲染的。当你明白这一点的时候就不难解释为什么有的壁纸不大,但是却给人一种挖矿的感觉,有的壁纸很大却完美运行。。。。目录吐槽:解决办法:总结吐槽:今天找到了一个很好看(屌丝)的壁纸,结果应用起来,却发现电脑卡顿严重(见下图),虽说我的显卡1650不是很好,可也不至于带不动个20多MB的壁纸吧???于是乎……..我发现是我想简单了,他这个壁纸是..

    2022年6月17日
    1.0K
  • Maven(三):将web项目的war包热部署到远程Tomcat服务器

    Maven(三):将web项目的war包热部署到远程Tomcat服务器

    2021年9月26日
    70
  • .NET程序的编译和运行

    程序的编译和运行,总得来说大体是:首先写好的程序是源代码,然后编译器编译为本地机器语言,最后在本地操作系统运行。下图为传统代码编译运行过程:.NET的编译和运行过程与之类似,首先编写好的源代码,然

    2021年12月22日
    52
  • 圆柱体积计算公式是_锥形体积公式

    圆柱体积计算公式是_锥形体积公式圆柱体积计算公式有哪些π是圆周率,一般取3.14r是圆柱底面半径h为圆柱的高圆柱体体积=底面积×高V=πr2h=V=sh还可以是v=1/2ch×r侧面积的一半×半径2圆柱体积相关公式圆柱的侧面积=底面圆的周长×高圆柱的表面积=上下底面面积+侧面积圆柱的体积=底面积×高3圆柱的体积怎么计算求圆柱体积先要求圆基的半径。两个圆都会做,因为它们大小相同。如果你已经知道半径,你可以继续前进。如果你不知道半径…

    2022年9月19日
    0

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号