代码随想录算法训练营第二十一天|二叉树 part8

669. 修剪二叉搜索树

其实就是判断当前节点的值与搜索区间的关系。

  1. 位于 [ l o w , h i g h ] [low, high] [low,high]: 继续遍历修剪左子树和右子树
  2. 位于 ( − ∞ , l o w ) (-\infty, low) (−∞,low): 返回修剪的右子树
  3. 位于 ( h i g h , + ∞ ) (high, +\infty) (high,+∞): 返回修剪的左子树
cpp 复制代码
class Solution {
public:
    TreeNode* trimBST(TreeNode* root, int low, int high) {
        if (root == nullptr)
            return nullptr;
        if (root->val < low)
            return trimBST(root->right, low, high);
        else if (root->val > high)
            return trimBST(root->left, low, high);
        else {
            root->left = trimBST(root->left, low, high);
            root->right = trimBST(root->right, low, high);
        }
        return root;
    }
};

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

本质就是寻找分割点,分割点作为当前节点,然后递归左区间和右区间。

cpp 复制代码
class Solution {
public:
    TreeNode* construct(vector<int>& nums, int left, int right) {
        //[left, right)
        if (left >= right)
            return nullptr;
        int middle = (left + right)/2;
        TreeNode* root = new TreeNode(nums[middle]);
        //[left, middle)
        root->left = construct(nums, left, middle);
        //[middle + 1, right);
        root->right = construct(nums, middle + 1, right);
        return root;
    }
    TreeNode* sortedArrayToBST(vector<int>& nums) {
        return construct(nums, 0, nums.size());
    }
};

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

cpp 复制代码
class Solution {
public:
    TreeNode* prev = nullptr;
    TreeNode* convertBST(TreeNode* root) {
        if (root == nullptr)
            return nullptr;
        
        root->right = convertBST(root->right);
        if (prev != nullptr)
            root->val += prev->val;
        prev = root;
        root->left = convertBST(root->left);
        return root;
    }
};
相关推荐
xiaoye-duck几秒前
《算法题讲解指南:优选算法-分治-归并》--47.归并排序,48.数组中的逆序对
c++·算法
Darkwanderor2 分钟前
图论——最短路问题
c++·算法·图论·最短路
Filotimo_2 分钟前
3.4 图
算法·图论
I_LPL3 分钟前
day49 代码随想录算法训练营 图论专题2
java·算法·深度优先·图论·广度优先·求职面试
小小unicorn3 分钟前
[微服务即时通讯系统]语音子服务的实现与测试
c++·算法·微服务·云原生·架构·xcode
xsyaaaan3 分钟前
代码随想录Day53图:Floyd算法精讲_ Astar算法精讲_最短路算法总结篇_图论总结
算法·图论
lihihi5 分钟前
P10471 最大异或对 The XOR Largest Pair
算法
漫随流水16 分钟前
备战蓝桥杯(3)
数据结构·c++·算法·蓝桥杯
song85460113420 分钟前
hash和history导航区别 个别服务器为啥不支持 history 模式
服务器·算法·哈希算法
IT猿手21 分钟前
多无人机动态避障路径规划研究:基于粒子群优化算法PSO的多无人机动态避障路径规划研究(可以自定义无人机数量及起始点),MATLAB代码
算法·matlab·机器人·无人机·路径规划·动态路径规划