LeetCode75| 二叉搜索树

目录

[700 二叉搜索树中的搜索](#700 二叉搜索树中的搜索)

迭代

递归

[450 删除二叉搜索树中的节点](#450 删除二叉搜索树中的节点)


700 二叉搜索树中的搜索

注意二叉搜索树的性质即可

迭代

cpp 复制代码
class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        while(root != NULL){
            if(root->val < val)root = root->right;
            else if(root->val > val)root = root->left;
            else return root;
        }
        return NULL;
    }
};

时间复杂度O(n)

空间复杂度O(n)

递归

cpp 复制代码
class Solution {
public:
    TreeNode* searchBST(TreeNode* root, int val) {
        if(root == NULL)return NULL;
        if(root->val == val)return root;
        return root->val > val?searchBST(root->left,val) : searchBST(root->right,val); 
    }
};

时间复杂度O(n)

空间复杂度O(1)

450 删除二叉搜索树中的节点

在删除待删除节点时有如下五种情况

  1. 没找到待删除节点,遍历到空节点后返回
  2. 待删除节点左右节点都为空,删除后直接返回空
  3. 待删除节点左节点为空,右节点不为空,删除节点后让右孩子作为根节点
  4. 待删除节点右节点为空,左节点不为空,删除节点后让左孩子作为根节点
  5. 待删除节点左右节点都不为空,将待删除节点的左孩子放到右孩子的最左节点的左孩子处,返回待删除节点的右孩子作为根节点
cpp 复制代码
class Solution {
public:
    TreeNode* deleteNode(TreeNode* root, int key) {
        if(root == NULL)return NULL;//情况一
        if(root->val == key){
            if(root->left == NULL && root->right == NULL)return NULL;//情况二
            else if(root->left == NULL && root->right != NULL)return root->right;//情况三
            else if(root->left != NULL && root->right == NULL)return root->left;//情况四
            else{//情况五
                TreeNode* cur = root->right;
                while(cur->left != NULL){
                    cur = cur->left;
                }
                cur->left = root->left;
                return root->right;
            }
        }
        if(root->val > key)root->left = deleteNode(root->left,key);
        if(root->val < key)root->right = deleteNode(root->right,key);
        return root;
    }
};

时间复杂度O(n)

空间复杂度O(n)

相关推荐
地平线开发者27 分钟前
征程 6E/M Matrix 开发评板使用系列(一):开箱与点亮
算法·自动驾驶
Jerry44 分钟前
LeetCode 59. 螺旋矩阵 II
算法
可编程芯片开发1 小时前
基于FOC控制器的BLDC无刷直流电机控制系统matlab编程与仿真
算法
aaaameliaaa1 小时前
进制练习题【找出只出现一次的数字、交换两个变量(不创建临时变量)、统计二进制中1的个数、打印整数二进制的奇数位和偶数位、求两个数二进制中不同位的个数】
c语言·数据结构·笔记·算法
QiLinkOS3 小时前
第三视觉理解徐玉生与他的商业活动(28)
大数据·c++·人工智能·算法·开源协议
wabs6664 小时前
关于动态规划【力扣1143.最长公共子序列的思考】
算法·leetcode·动态规划
剑挑星河月4 小时前
54.螺旋矩阵
java·算法·leetcode·矩阵
Robot_Nav4 小时前
MPPI 局部规划器实验设计讲解
人工智能·算法·mppi
mingo_敏5 小时前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
星空露珠5 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua