【leetcode100-042/043】【二叉树】二叉搜索树的转换和验证

【转换】

给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。

高度平衡二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。

思路:

可以说是递归板子题了。每次把数组切两半,中间数据拿来做根节点,左边部分继续建左子树,右边部分继续建右子树,只需要注意更改传入的参数就好啦。

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

【验证】

给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。

有效 二叉搜索树定义如下:

  • 节点的左子树只包含小于当前节点的数。
  • 节点的右子树只包含 大于 当前节点的数。
  • 所有左子树和右子树自身必须也是二叉搜索树。

思路:

一开始写了个经典错误版,也就是在判断环节只验证了左右孩子和父节点的关系是否合法,但我们要的其实是左子树所有节点都必须合法。

为此我们引入一个上下界的概念。通过传参实时地限定当前子树中所有节点的合法取值范围。

显然,对某个节点的左子树来说,其下界和以该节点为根节点的整个二叉树是相同的,而其上界则是该节点自身的值,右子树同理,只是改变的是下界。

虽说是整个子树的上下界,但我们只要检查左右孩子就可以,因为递归函数会帮助我们检查到所有的节点,而越小的子树其上下界范围只会越严格,所以不可能出现某节点在小子树时合法而在更大的子树中非法的情况。

cpp 复制代码
class Solution {
public:
    bool check(TreeNode* root, long long lower, long long upper) {
        if (root == nullptr)
            return true;
        return (root->val > lower) && (root->val < upper) &&
               check(root->left, lower, root->val) &&
               check(root->right, root->val, upper);
    }
    bool isValidBST(TreeNode* root) { return check(root, LONG_MIN, LONG_MAX); }
};
相关推荐
QxQ么么2 小时前
移远通信(桂林)26校招-助理AI算法工程师-面试纪录
人工智能·python·算法·面试
Mz12214 小时前
day05 移动零、盛水最多的容器、三数之和
数据结构·算法·leetcode
SoleMotive.4 小时前
如果用户反映页面跳转得非常慢,该如何排查
jvm·数据库·redis·算法·缓存
念越4 小时前
判断两棵二叉树是否相同(力扣)
算法·leetcode·入门
complexor4 小时前
NOIP 2025 游记
数据结构·数学·动态规划·贪心·组合计数·树上问题·游记&总结
牢七5 小时前
数据结构1111
数据结构
ghie90905 小时前
线性三角波连续调频毫米波雷达目标识别
人工智能·算法·计算机视觉
却话巴山夜雨时i5 小时前
74. 搜索二维矩阵【中等】
数据结构·算法·矩阵
sin_hielo5 小时前
leetcode 3512
数据结构·算法·leetcode