繁体   English   中英

无法理解二进制搜索树删除

[英]Not able to understand Binary Search Tree Delete

我试图从此链接BinarySearchTree了解BST。 但是我对其他部分感到困惑

 /* Functions to delete data */
 public void delete(int k)
 {
     if (isEmpty())
         System.out.println("Tree Empty");
     else if (search(k) == false)
         System.out.println("Sorry "+ k +" is not present");
     else
     {
         root = delete(root, k);
         System.out.println(k+ " deleted from the tree");
     }
 }
 private BSTNode delete(BSTNode root, int k)
 {
     BSTNode p, p2, n;
     if (root.getData() == k)
     {
         BSTNode lt, rt;
         lt = root.getLeft();
         rt = root.getRight();
         if (lt == null && rt == null)
             return null;
         else if (lt == null)
         {
             p = rt;
             return p;
         }
         else if (rt == null)
         {
             p = lt;
             return p;
         }
         else
         {
             p2 = rt;
             p = rt;
             while (p.getLeft() != null)
               p = p.getLeft();
             p.setLeft(lt);
             return p2;
         }
     }
     if (k < root.getData())
     {
         n = delete(root.getLeft(), k);
         root.setLeft(n);
     }
     else
     {
         n = delete(root.getRight(), k);
         root.setRight(n);             
     }
     return root;
 }

我无法理解其他部分,其中找到右侧子树的最左侧节点,然后将其分配给该节点。 但是这里两个节点都不为空,并且没有返回正确的节点,这对我来说没有意义。 我希望这是一个正确的实现。 有人可以帮助我了解这里发生了什么。

关键概念是您在谈论二进制搜索树 如您所知,BST是有序结构,这意味着对于每棵树,左子树中包含的元素都是次要的或等于树的根。

此代码中的最后else块涵盖删除具有两个子节点的节点的情况。

该代码似乎在做的是:

  • 查找顺序后继节点(即,右侧子树中的最左侧节点)
  • 将整个原始的左子树附加到此节点
  • 返回原始的正确的孩子作为树的新根

尽管这种迭代实现对我来说似乎是正确的,但我猜想在执行几次删除操作后,您最终会得到不平衡的树。

尽管起初较难理解,但删除操作的递归实现通常更易于阅读。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM