算法学习 | day19/60 二叉搜索树的最近公共祖先/二叉搜索树中的插入操作/删除二叉搜索树中的节点

一、题目打卡

1.1 二叉搜索树的最近公共祖先(借助答案的思路)

题目链接:. - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    TreeNode* lowestCommonAncestor(TreeNode* root, TreeNode* p, TreeNode* q) {
        if(!root) return root;
        if(root->val > p->val && root->val > q->val){
            TreeNode* left = lowestCommonAncestor(root->left,p,q);
            if(left) return left;
        }
        if(root->val < p->val && root->val < q->val){
            TreeNode* right = lowestCommonAncestor(root->right,p,q);
            if(right) return right;
        }
        return root;
    }
};

这个题目同样利用了二叉搜索树的特性,比较关键的一个点就是公共祖先一定在 p 和 q 的val 的中间,而由这一点去由上向下找到的第一个满足条件的祖先,肯定就是需要找到的那个,因为此时深度肯定是最大的,题目本身也利用的剪枝的特点。

1.2 二叉搜索树的插入操作

题目链接:. - 力扣(LeetCode)

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

有一点受上一个题目的启发,理由二叉搜索树的特点来区分递归的条件,这个题目我感觉比较巧妙的是最终结束的条件,也就是结束时候的位置,其实就应该是这个节点应该存在的位置。

1.3 删除二叉搜索树的节点

题目链接:. - 力扣(LeetCode)

cpp 复制代码
class Solution {
public:
    TreeNode* deleteNode(TreeNode* root, int key) {
        if(!root) return nullptr;
        root->left = deleteNode(root->left,key);
        root->right = deleteNode(root->right,key);
        if(root->val == key){
            if(!root->left && !root->right) return nullptr;
            if(root->left || root->right){
                if(root->left){
                    TreeNode* tmp = root->left;
                    while(tmp->right) tmp = tmp->right;
                    tmp->right = root->right;
                    TreeNode* res = root->left;
                    delete root;
                    return res;
                }else{
                    TreeNode* tmp = root->right;
                    while(tmp->left) tmp = tmp->left; // 关键是理解这个过程
                    tmp->left = root->left;
                    // 这一步不能少
                    TreeNode* res = root->right;
                    delete root;
                    return res;
                }
            }
        }
        return root;
    }
};

题目理解起来其实不是很复杂,主要是理解这个迭代的过程,

这个主要的就是要理解为什么要使用 while ,因为需要找到最后一个满足插入条件的位置,这样才能保证二叉搜索树的性质维持,感觉答案分的情况有点多,应该是那样更清晰吧。

相关推荐
野犬寒鸦32 分钟前
从零起步学习并发编程 || 第四章:synchronized底层源码级讲解及项目实战应用案例
java·服务器·开发语言·jvm·后端·学习·面试
!停33 分钟前
数据结构二叉树——堆
java·数据结构·算法
£漫步 云端彡37 分钟前
Golang学习历程【第十一篇 接口(interface)】
开发语言·学习·golang
一匹电信狗9 小时前
【LeetCode_547_990】并查集的应用——省份数量 + 等式方程的可满足性
c++·算法·leetcode·职场和发展·stl
鱼跃鹰飞9 小时前
Leetcode会员尊享100题:270.最接近的二叉树值
数据结构·算法·leetcode
梵刹古音10 小时前
【C语言】 函数基础与定义
c语言·开发语言·算法
筵陌11 小时前
算法:模拟
算法
wdfk_prog11 小时前
[Linux]学习笔记系列 -- [drivers][i2c]i2c-dev
linux·笔记·学习
We་ct11 小时前
LeetCode 205. 同构字符串:解题思路+代码优化全解析
前端·算法·leetcode·typescript
renhongxia111 小时前
AI算法实战:逻辑回归在风控场景中的应用
人工智能·深度学习·算法·机器学习·信息可视化·语言模型·逻辑回归