美文网首页
Leetcode 450. 删除二叉搜索树中的节点(BST的删除

Leetcode 450. 删除二叉搜索树中的节点(BST的删除

作者: 进击的Lancelot | 来源:发表于2020-06-18 11:02 被阅读0次

    问题描述

    给定一个二叉搜索树的根节点 root 和一个值 key,删除二叉搜索树中的 key 对应的节点,并保证二叉搜索树的性质不变。返回二叉搜索树(有可能被更新)的根节点的引用。
    一般来说,删除节点可分为两个步骤:

    • 首先找到需要删除的节点;
    • 如果找到了,删除它。

    说明: 要求算法时间复杂度为 O(h),h 为树的高度。

    Example

    root = [5,3,6,2,4,null,7]
    key = 3



    给定需要删除的节点值是 3,所以我们首先找到 3 这个节点,然后删除它。

    一个正确的答案是 [5,4,6,2,null,null,7], 如下图所示。
    另一个正确答案是 [5,2,6,null,4,null,7], 如下图所示。 image.png

    题目链接:450. 删除二叉搜索树中的节点 (难度:中等)

    思路

    从题目描述中可知,我们需要做的事情有两个:找到节点和删除节点。我们考虑删除当前节点的情况:

    • 若当前节点是叶节点,则直接删除
    • 若当前节点的左右孩子中有一棵为空,则用另一个子树代替当前节点
    • 若当前节点的左右孩子均非空,我们统一将左子树作为根节点,并将右子树挂到左子树的最右结点的右端

    其中,第一种情况是第二种情况的特例

    代码

    class Solution {
    public:
        TreeNode* deleteNode(TreeNode* root, int key) {
            if(root == NULL)
                return NULL;
            if(root->val == key){
                if(root->left && root->right){
                    TreeNode* tmp = root->left;
                    while(tmp->right){
                        tmp = tmp->right;
                    }
                    tmp->right = root->right;
                    return root->left;
                }
                return root->right == NULL ? root->left : root->right;
            }else if(root->val < key){
                root->right = deleteNode(root->right, key);
            }else{
                root->left = deleteNode(root->left, key);
            }
            return root;
        }
    };
    

    执行结果:64 ms,32.5 MB

    相关文章

      网友评论

          本文标题:Leetcode 450. 删除二叉搜索树中的节点(BST的删除

          本文链接:https://www.haomeiwen.com/subject/ehnyxktx.html