首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

在BST Python中删除节点

在二叉搜索树(Binary Search Tree, BST)中删除节点是一个常见的操作。BST是一种特殊的二叉树,其中每个节点的值都大于其左子树中的任何节点值,并且小于其右子树中的任何节点值。

基础概念

删除BST中的节点主要有三种情况:

  1. 叶子节点:没有子节点的节点。
  2. 单子节点:只有一个子节点的节点。
  3. 双子节点:有两个子节点的节点。

相关优势

删除节点的操作有助于维护BST的性质,保持树的平衡和搜索效率。

类型

  • 叶子节点删除:直接删除。
  • 单子节点删除:用其子节点替换该节点。
  • 双子节点删除:找到右子树中的最小节点或左子树中的最大节点替换该节点,然后删除那个最小/最大节点。

应用场景

BST常用于实现高效的查找、插入和删除操作,广泛应用于数据库索引、编译器符号表、文件系统等。

删除节点的Python实现

以下是一个简单的BST节点删除的Python示例:

代码语言:txt
复制
class TreeNode:
    def __init__(self, key):
        self.left = None
        self.right = None
        self.val = key

def minValueNode(node):
    current = node
    while(current.left is not None):
        current = current.left
    return current

def deleteNode(root, key):
    if root is None:
        return root
    
    if key < root.val:
        root.left = deleteNode(root.left, key)
    elif(key > root.val):
        root.right = deleteNode(root.right, key)
    else:
        if root.left is None:
            temp = root.right
            root = None
            return temp
        elif root.right is None:
            temp = root.left
            root = None
            return temp
        
        temp = minValueNode(root.right)
        root.val = temp.val
        root.right = deleteNode(root.right, temp.val)
    return root

可能遇到的问题及解决方法

  1. 树失去平衡:删除节点后,树可能会变得不平衡,导致搜索效率下降。解决方法是使用自平衡二叉搜索树(如AVL树或红黑树)。
  2. 递归深度过大:对于非常大的树,递归删除可能会导致栈溢出。解决方法是使用迭代方法实现删除操作。
  3. 节点不存在:尝试删除不存在的节点会导致错误。解决方法是在删除前检查节点是否存在。

参考链接

二叉搜索树删除节点详解

通过上述方法和代码示例,可以有效地在BST中删除节点,并处理可能遇到的问题。

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • LeetCode 450: 删除二叉搜索树节点 Delete Node in a BST

    题目: 给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。...Given a root node reference of a BST and a key, delete the node with the given key in the BST....5 / \ 2 6 \ \ 4 7 解题思路: 待删除节点在二叉树的三种情况有: 如果目标节点没有子节点,我们可以直接移除该目标节点。...另外二叉搜索树的序遍历结果为从小到大顺序排列的; 删除节点如果不是叶子节点时, 则应把该节点的值替换为其右子树中最小的一个节点值 (删除节点的后驱节点); 删除节点如果不是叶子节点且无右子树时, 则应把该节点的值替换为其左子树中最大的一个节点值...(删除节点的前驱节点), 并在子树递归删除刚刚替换的节点 你会发现, 二叉搜索树最小节点为该树的最左叶子; 最大节点为该树的最右叶子, 即: 如果 key > root.val,说明要删除节点在右子树

    1.1K20

    删除链表节点

    题目描述 难度级别:简单 请编写一个函数,使其可以删除某个链表给定的(非末尾)节点。传入函数的唯一参数为 要被删除节点 。...,那么调用了你的函数之后,该链表应变为 4 -> 1 -> 9....提示: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表的一个有效节点。 不要从你的函数返回任何结果。...解题思路 题目中待传递给当前函数的实参node,它是链表的某一个待删除节点,然后从链表删除这个节点。...这里因为待传入的实参没有完整的链表,所以无法获取到之前节点,所以无法修改前一个节点的next指向。这时需要的是将要删除节点的值替换为它的下一个节点的值,之后要删除这个节点的next指向为下下一项。

    2.4K00

    2 删除链表节点

    复习链表的插入 链表的一个节点是由数据域和指针域构成,指针域的地址值为下个元素的地址。那么我们需要插入或者删除一个元素怎么处理呢? ? 先查看原始链表结构,准备将结点x插入链表。 ?...复习链表的删除 上面简单介绍了带头结点的链表,删除处理的时候同样适用,所以我们以后就直接采用带头结点的链表讲解。下面直接看看删除节点图。 ?...1 Leetcode237 删除链表的节点 请编写一个函数,使其可以删除某个链表给定的(非末尾)节点,你将只被给定要求被删除节点。...说明: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表的一个有效节点。 不要从你的函数返回任何结果。 先思考一分钟哟! 效果更好哈!...2 python版本 ? 3 java版本 ?

    1.3K20

    237 删除链表节点

    01 题目信息 题目地址: https://leetcode-cn.com/problems/delete-node-in-a-linked-list/ 请编写一个函数,使其可以删除某个链表给定的(非末尾...示例 1: 输入:head = [4,5,1,9], node = 5 输出:[4,1,9] 解释:给定你链表中值为 5 的第二个节点,那么调用了你的函数之后,该链表应变为 4 -> 1 -> 9....示例 2: 输入:head = [4,5,1,9], node = 1 输出:[4,5,9] 解释:给定你链表中值为 1 的第三个节点,那么调用了你的函数之后,该链表应变为 4 -> 5 -> 9....提示: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表的一个有效节点。 不要从你的函数返回任何结果。...x) { val = x; } } 现在它传一条链表的一个节点删除这个节点

    1.3K10

    删除链表的重复节点.

    前言 一个排序的链表,存在重复的节点,如何删除链表重复的节点并返回删除后的链表头指针?例如:1->2->3->3->4->4->5,处理后为: 1->2->5。...常规思路 根据题意,我们可以知道链表的元素是排好序的。如果节点重复的话,当前节点一定与下一个节点相同。...那么,我们只需要从第一个元素开始向后比对每个元素,修改节点的指针至不重复的节点,即可完成对重复节点删除。...20220226224625702 实现代码 接下来,我们将上述思路转换为代码,如下所示: /** * 删除链表的重复节点 * @param pHead 链表头节点 */ deleteDuplicatesNode...我们将文章开头所举的例子,代入上述思路,画一下它的递归栈帮助大家更好的理解,如下所示: image-20220228231355965 实现代码 接下来,我们将上述思路转换为代码,如下所示: /** * 删除链表的重复节点

    2.8K40

    Swift 删除链表节点 - LeetCode

    LeetCode 题目: 删除链表节点 请编写一个函数,使其可以删除某个链表给定的(非末尾)节点,你将只被给定要求被删除节点。...4,5,1,9,它可以表示为: 4 -> 5 -> 1 -> 9 示例1: 输入: head = [4,5,1,9], node = 5 输出: [4,1,9] 解释: 给定你链表中值为 5 的第二个节点...,那么调用了你的函数之后,该链表应变为 4 -> 1 -> 9....示例2: 输入: head = [4,5,1,9], node = 1 输出: [4,5,9] 解释: 给定你链表中值为 1 的第三个节点,那么调用了你的函数之后,该链表应变为 4 -> 5 -> 9...说明: 链表至少包含两个节点。 链表中所有节点的值都是唯一的。 给定的节点为非末尾节点并且一定是链表的一个有效节点。 不要从你的函数返回任何结果。

    1.3K40

    Redis3 集群删除节点

    image.png 删除节点有两种情况: (1)删除master节点,需要先把目标节点中的slot移动到其他节点中,然后执行删除节点操作 (2)删除slave节点,直接执行删除操作 删除master (...1)执行重新分片操作 redis-trib.rb reshard 127.0.0.1:7000 依次输入:要移动的slot数量(要删除节点上的slot数量)、接受slot的节点ID、移动源节点ID(要删除节点的...ID)、done,输出移动计划后输入:yes,开始执行移动操作 查看集群节点信息,看要删除节点上的slot数量是否为0 redis-trib.rb check 127.0.0.1:7000 (2)执行删除操作...redis-trib.rb check 127.0.0.1:7000 可以看到删除操作成功了 另外,之前删除的master节点是有slave的,被删除后slave如何处理了呢?...这里可以看到,这个slave被自动分配给另一个master了 删除slave 直接执行删除节点的操作 redis-trib.rb del-node 127.0.0.1:7000 要删除节点的ID 查看集群节点信息

    1K60
    领券