
🔥 个人主页: 黑洞晓威
😀你不必等到非常厉害,才敢开始,你需要开始,才会变的非常厉害
98. 验证二叉搜索树
给你一个二叉树的根节点 root ,判断其是否是一个有效的二叉搜索树。
有效 二叉搜索树定义如下:
-  节点的左 子树 只包含 小于 当前节点的数。 
-  节点的右子树只包含 大于 当前节点的数。 
-  所有左子树和右子树自身必须也是二叉搜索树。 
 
 
解题思路
- 利用递归检查每个节点是否在正确的范围内。
- 对于左子树,它的值范围为负无穷到根节点值。
- 对于右子树,它的值范围为根节点值到正无穷。
- 每个节点带有上下界(最小值和最大值),在遍历节点时更新这些上下界。
代码实现
class Solution {
    public boolean isValidBST(TreeNode root) {
        return isValidBST(root, Long.MIN_VALUE, Long.MAX_VALUE);
    }
    private boolean isValidBST(TreeNode node, long min, long max) {
        if (node == null) {
            return true;
        }
        if (node.val <= min || node.val >= max) {
            return false;
        }
        return isValidBST(node.left, min, node.val) && isValidBST(node.right, node.val, max);
    }
}
108. 将有序数组转换为二叉搜索树
给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵
平衡二叉搜索树。
解题思路
- 找到数组的中间元素作为根节点。
- 数组被中间元素分成了左右两部分,分别递归构建左子树和右子树。
- 递归的结束条件是左边界大于右边界,此时返回null。
代码实现
class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
        if (nums == null || nums.length == 0) {
            return null;
        }
        
        return constructBST(nums, 0, nums.length - 1);
    }
    
    private TreeNode constructBST(int[] nums, int left, int right) {
        if (left > right) {
            return null;
        }
        
        int mid = left + (right - left) / 2;
        TreeNode root = new TreeNode(nums[mid]);
        
        root.left = constructBST(nums, left, mid - 1);
        root.right = constructBST(nums, mid + 1, right);
        
        return root;
    }
}



















