二叉查找树 ﹏ヽ暗。殇╰゛Y 2021-09-22 09:40 563阅读 0赞 二叉查找树有这几个规则 1、若左子树不为空,那么左子树所有节点的值小于均小于他的根节点的值。 2、若右子树不为空,那么右子树的所有节点的值大于根节点的值。 3、左右子树也分别为二叉树排序树。 4、没有键值相等的节点。 注意:每个值都不能一样,如果有一样的,我们不需做考虑。 添加挺简单的,看下面的代码。 首先做准备 // 主要用来保存节点 private Node<T> root ; // 用来操作节点的 private Node<T> opRoot ; // 用来存放元素,准备遍历元素,放到list集合种 private List<T> list = new ArrayList<>(); 上面这些是准备数据 还需注意一下:Node里面除了左右节点外,还有指向父节点的parent 下面这些是真真的操作 public void insert(T t)\{ if(opRoot == null)\{ root.setT(t); opRoot = root; return ; \} opRoot = root ; Node<T> node = new Node<T>(); node.setT(t); insert(opRoot , node) ; \} // 这里使用的最简单递归方式,如果觉得这个简单你可以试试非递归的方式 private void insert(Node<T> opRoot, Node<T> node) \{ if(opRoot.getT().compareTo(node.getT()) > 0)\{ if(opRoot.getLeft() != null)\{ insert(opRoot.getLeft() , node ) ; \}else \{ opRoot.setLeft(node); node.setParent(opRoot); \} \} if(opRoot.getT().compareTo(node.getT()) < 0)\{ if(opRoot.getRight() != null)\{ insert(opRoot.getRight() , node) ; \}else \{ opRoot.setRight(node); node.setParent(opRoot); \} \} \} 现在重点来了: 请看下面这个图 假设,我们删除元素4 删除之后会变成这样。 我先提出一种,我做了两个小时写if else ,从第一个元素判断,先找出删除这个元素的parent(父节点)、left(左子树)、right(右子树)。先考虑的是父,父节点如果为空,按一般原则 我们需要考虑右子树,右子树是不是为空,如果为空了,我们需要判断左子树,左子树是不是为空,如果左子树为空了,我们返回null,如果不为空,我们返回左子树就行,如果 右子树不为null,我们把左子树放在右子树的最左边的下面。然后就这样if else 一直下去,做了两个小时,没做出来。 这个是我新想出来的,首先我们不考虑那么多,我只考虑那个结点下面的左子树和右子树,我们先把左子树放到右子树的最下的左子树,代码如下: if(right == null )\{ right = left ; \} else \{ Node<T> rightLeft = findLeft(right.getLeft()); if(rightLeft == null )\{ right.setLeft(left); if(left != null)\{ left.setParent(right); \} \}else\{ rightLeft.setLeft(left); if(left != null ) \{ left.setParent(rightLeft); \} \} \} \} 这里减少了很多需要考虑的东西,我们只需要考虑这个结点下的左子树和右子树,如果左子树为空,我们就把左子树放到右子树那,下面就不能考虑左子树了。 下面我们只需要判断结点的右子树和父结点 代码如下 if(parent == null) \{ root = right ; \}else \{ if ( right == null ) \{ leftOrRightIsNull(parent , node) ; \}else \{ leftOrRight(parent , right ) ; \} \} \} 下面是完整的删除代码 // 删除值 public Node<T> delete(T t)\{ Node<T> node = query(t); if(node == null )\{ return null ; \} delete(node); return node ; \} private void delete(Node<T> node) \{ Node<T> parent = node.getParent() ; Node<T> right = node.getRight() ; Node<T> left = node.getLeft() ; if(right == null )\{ right = left ; \} else \{ Node<T> rightLeft = findLeft(right.getLeft()); if(rightLeft == null )\{ right.setLeft(left); if(left != null)\{ left.setParent(right); \} \}else\{ rightLeft.setLeft(left); if(left != null ) \{ left.setParent(rightLeft); \} \} \} // 这里如果是node=right,只是把node执行别的地方,并没有真的删除了 if(parent == null) \{ root = right ; \}else \{ if ( right == null ) \{ leftOrRightIsNull(parent , node) ; \}else \{ leftOrRight(parent , right ) ; \} \} \} // 当父类元素不能空,右边没有元素,把这个元给清除了 private void leftOrRightIsNull(Node<T> parent, Node<T> node) \{ if(parent.getLeft().getT().compareTo(node.getT()) == 0)\{ parent.setLeft(node.getLeft()); \}else\{ parent.setRight(node.getLeft()); \} \} // 判断是删除父类左边还是父类右边,然后给删除了 private void leftOrRight(Node<T> parent, Node<T> right) \{ if(parent.getLeft().getT().compareTo(right.getParent().getT()) == 0)\{ parent.setLeft(right); \}else\{ parent.setRight(right); \} right.setParent(parent); \} private Node<T> findLeft(Node<T> left) \{ if(left == null ) \{ return null; \} if(left.getLeft() == null)\{ return left ; \}else\{ return findLeft(left.getLeft()); \} \} \# 如何觉得能帮助你,麻烦给作者一份信任,让作者能写下去的理由,不需要你给的太多,只需1块钱即可。 !\[在这里插入图片描述\](https://img-blog.csdnimg.cn/20200328012323201.png?x-oss-process=image/watermark,type\_ZmFuZ3poZW5naGVpdGk,shadow\_10,text\_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoaWJhaTkwNg==,size\_16,color\_FFFFFF,t\_70) !\[在这里插入图片描述\](https://img-blog.csdnimg.cn/2020032801220920.png?x-oss-process=image/watermark,type\_ZmFuZ3poZW5naGVpdGk,shadow\_10,text\_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoaWJhaTkwNg==,size\_16,color\_FFFFFF,t\_70) \# 如果作者写的有误或者想和作者分享更多,请添加作者微信,邀你进群需收10块钱群费。收钱的目的在于我们来着是学知识的,不是来着观望的 !\[在这里插入图片描述\](https://img-blog.csdnimg.cn/20200328012545973.png?x-oss-process=image/watermark,type\_ZmFuZ3poZW5naGVpdGk,shadow\_10,text\_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L3NoaWJhaTkwNg==,size\_16,color\_FFFFFF,t\_70)
相关 leetcode——二叉树、二叉查找树 leetcode——二叉树、二叉查找树 104. 二叉树的最大深度 111. 二叉树的最小深度 226. 翻转二叉树 r囧r小猫/ 2022年09月05日 12:39/ 0 赞/ 261 阅读
相关 二叉查找树 二叉查找树是二叉树中最常用的一种类型,也叫二叉搜索树。顾名思义,二叉查找树是为了实现快速查找而生的。不过,它不仅仅支持快速查找一个数据,还支持快速插入、删除一个数据。它是怎么做 港控/mmm°/ 2022年08月28日 03:51/ 0 赞/ 263 阅读
相关 二叉查找树 本文将会介绍一种能够将链表插入的灵活性和有序数组查找的高效性结合在一起的符号表实现。 定义 一颗二叉查找树(BST)是一颗二叉树,其中每个结点都含有一个Comparab 布满荆棘的人生/ 2022年07月16日 00:22/ 0 赞/ 239 阅读
相关 二叉查找树 package 树; /\\ \ 定义一个结点 \/ class Node\{ Node left = null; Node righ ╰+攻爆jí腚メ/ 2022年05月26日 07:49/ 0 赞/ 356 阅读
相关 二叉树(四)---查找二叉树 上次我说了如何去遍历一棵二叉树,今天我来说一说查找二叉树是怎样实现的。 首先我来介绍一下查找二叉树是怎样生成的。 这个是我为我的二叉树设置的一些基础的组成数据结构 深碍√TFBOYSˉ_/ 2022年05月25日 09:37/ 0 赞/ 290 阅读
相关 二叉查找树 <table> <tbody> <tr> <td> <p>package 树;</p> <p>import java.util.Stack;</p> <p>/ 我就是我/ 2022年05月13日 01:40/ 0 赞/ 289 阅读
相关 二叉查找树 二叉查找树 概念 二叉查找树,又称为二叉排序树、二叉搜索树。 二叉查找树有以下几个特性 若左子树不空,则左子树上所有结点的值均小于它的根结点的值 若 旧城等待,/ 2022年04月10日 02:39/ 0 赞/ 498 阅读
相关 二叉查找树 / 这是一个二叉查找树,实现了以下操作:插入结点、构造二叉树、删除结点、查找、 查找最大值、查找最小值、查找指定结点的前驱和后继。上述所有操作时 迈不过友情╰/ 2022年02月26日 11:48/ 0 赞/ 353 阅读
相关 二叉查找树 二叉查找树有这几个规则 1、若左子树不为空,那么左子树所有节点的值小于均小于他的根节点的值。 2、若右子树不为空,那么右子树的所有节点的值大于根节点的值。 3、左右子树也 ﹏ヽ暗。殇╰゛Y/ 2021年09月22日 09:40/ 0 赞/ 564 阅读
相关 二叉查找树 理解 在二叉树的基础上,假设一个节点值都为Integer类型,现在有一个节点A,那么A的左子树中的所有值一定小于A节点的值,A的右子树中的所有值一定大于A的节点的值,如果 清疚/ 2021年09月11日 06:56/ 0 赞/ 553 阅读
还没有评论,来说两句吧...