• 代码随想录 10.14 || 二叉树 LeetCode 669.修剪二叉搜索树、108.将有序数组转换为二叉搜索树、538.将二叉搜索树转为累加树


    669.修剪二叉搜索树

            根据给定的最小边界 left 和最大边界 right 修剪二叉搜索树,保留值在 left ~ right 的节点,删除不满足此条件的节点。修剪树不应该改变保留在树中的元素的相对结构,即父子关系。

            设 cur 为当前访问的二叉树节点,可分为以下情况:

            1)cur->val 小于 left,当前节点应该被删除,但是根据二叉搜索树的性质,当前节点的右子树可能满足 cur->val 大于 left,即不能删除以当前节点为根的整棵二叉树,应该仅删除当前节点,还需要遍历其右子树;

            2)cur-> val 大于 right,当前节点应该被删除,根据二叉搜索树的性质,当前节点的左子树可能满足 cur->val 小于 right,还需要遍历其左子树;

            3)cur->val 满足给定区间,此时继续向下遍历即可。

    1. class Solution {
    2. public:
    3. TreeNode* trimBST(TreeNode *root, int low, int high) {
    4. if (root == nullptr) return nullptr;
    5. if (root->val < low) return trimBST(root->right, low, high);
    6. if (root->val > high) return trimBST(root->left, low, high);
    7. root->left = trimBST(root->left, low, high);
    8. root->right = trimBST(root->right, low, high);
    9. return root;
    10. }
    11. };

    108.将有序数组转换为二叉搜索树

            二叉搜索树要求:其右子树的值大于根节点,左子树的值小于根节点,左右子树均满足这个条件。因此,根节点是中间的值,所以从有序数组的中间一分为二,左边初始化为左子树,右边初始化为右子树。

    1. class Solution {
    2. private:
    3. TreeNode* traversal(vector<int> &nums, int left, int right) {
    4. if (left > right) return nullptr;
    5. int mid = left + ((right - left) / 2);
    6. TreeNode *node = new TreeNode(nums[mid]);
    7. node->left = traversal(nums, left, mid - 1);
    8. node->right = traversal(nums, mid + 1, right);
    9. return node;
    10. }
    11. public:
    12. TreeNode* sortedArrayToBST(vector<int>& nums) {
    13. TreeNode *root = traversal(nums, 0, nums.size() - 1);
    14. return root;

    538.将二叉搜索树转换为累加树

    1. class Solution {
    2. private:
    3. int pre = 0;
    4. void traversal(TreeNode *cur) {
    5. if (cur == nullptr) return;
    6. traversal(cur->right);
    7. cur->val += pre;
    8. pre = cur->val;
    9. traversal(cur->left);
    10. }
    11. public:
    12. TreeNode* convertBST(TreeNode *root) {
    13. pre = 0;
    14. traversal(root);
    15. return root;
    16. }
    17. };

  • 相关阅读:
    HTTP协议
    如何在Linux将Spring Boot项目的Jar包注册为开机自启动系统服务
    【力扣每日一题】2023.10.10 移动机器人
    ffmpeg常用命令
    JAVA图形化界面设计
    (王道考研计算机网络)第四章网络层-第五节3:BGP协议
    【Linux】8.0 多线程
    webstorm实用技巧
    记一次 .NET 某餐饮小程序 内存暴涨分析
    Ubuntu 22.04 无法使用网易云音乐
  • 原文地址:https://blog.csdn.net/weixin_73177736/article/details/134560585