【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); }
};
相关推荐
机器学习之心33 分钟前
量子遗传算法是一种将量子计算原理与遗传算法相结合的智能优化算法,代表了进化计算的一个有趣分支
算法·量子计算
Miraitowa_cheems1 小时前
LeetCode算法日记 - Day 59: 字母大小写全排列、优美的排列
java·数据结构·算法·leetcode·决策树·职场和发展·深度优先
岑梓铭1 小时前
《考研408数据结构》第三章(3.1 栈)复习笔记
数据结构·笔记·考研·408
未知陨落2 小时前
LeetCode:81.爬楼梯
算法·leetcode
SHtop112 小时前
排序算法(golang实现)
算法·golang·排序算法
Rain_is_bad2 小时前
初识c语言————数学库函数
c语言·开发语言·算法
Zzzzmo_3 小时前
Java数据结构:ArrayList与顺序表2
java·数据结构
艾醒4 小时前
大模型面试题剖析:模型微调中冷启动与热启动的概念、阶段与实例解析
深度学习·算法
新学笺4 小时前
数据结构与算法 —— 从基础到进阶:带哨兵的单向链表,彻底解决边界处理痛点
算法
智者知已应修善业4 小时前
【51单片机计时器1中断的60秒数码管倒计时】2023-1-23
c语言·经验分享·笔记·嵌入式硬件·算法·51单片机