108. 将有序数组转换为二叉搜索树 --力扣 --JAVA

简介: 给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。

 题目

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

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

解题思路

    1. 可以采用二分法,每次选数组中间值为根节点创建树,这样可以确保左右子树的高度差的绝对值不超过1;
    2. 通过递归来逐级生成后续节点;
    3. 可通过变量设置左右边界,方便后续节点区间的取值;

    代码展示

    class Solution {
        public TreeNode sortedArrayToBST(int[] nums) {
            TreeNode data = toBST(nums, 0, nums.length - 1);
            return data;
        }
        public TreeNode toBST(int[] nums, int left, int right){
            if(left > right){
                return null;
            }
            int middle = (left + right) / 2;
            return new TreeNode(nums[middle], toBST(nums, left, middle - 1), toBST(nums, middle + 1, right));
        }
    }

    image.gif


    目录
    相关文章
    |
    Go 索引 Perl
    【LeetCode 热题100】【二叉树构造题精讲:前序 + 中序建树 & 有序数组构造 BST】(详细解析)(Go语言版)
    本文详细解析了二叉树构造的两类经典问题:通过前序与中序遍历重建二叉树(LeetCode 105),以及将有序数组转化为平衡二叉搜索树(BST,LeetCode 108)。文章从核心思路、递归解法到实现细节逐一拆解,强调通过索引控制子树范围以优化性能,并对比两题的不同构造逻辑。最后总结通用构造套路,提供进阶思考方向,帮助彻底掌握二叉树构造类题目。
    904 9
    |
    存储 算法 Java
    解锁“分享文件”高效密码:探秘 Java 二叉搜索树算法
    在信息爆炸的时代,文件分享至关重要。二叉搜索树(BST)以其高效的查找性能,为文件分享优化提供了新路径。本文聚焦Java环境下BST的应用,介绍其基础结构、实现示例及进阶优化。BST通过有序节点快速定位文件,结合自平衡树、多线程和权限管理,大幅提升文件分享效率与安全性。代码示例展示了文件插入与查找的基本操作,适用于大规模并发场景,确保分享过程流畅高效。掌握BST算法,助力文件分享创新发展。
    【LeetCode 48】108.将有序数组转换为二叉搜索树
    【LeetCode 48】108.将有序数组转换为二叉搜索树
    193 0
    leetCode(删除有序数组中的重复项)
    如何在不使用额外空间的情况下,通过双指针法原地删除有序数组中的重复项。
    190 2
    |
    算法 Java
    LeetCode(一)Java
    LeetCode(一)Java
    239 0
    LeetCode第88题合并两个有序数组
    文章分享了LeetCode第88题"合并两个有序数组"的解法,通过从后向前的合并策略避免了数组元素的前移,使用三个指针高效地完成了合并过程。
    LeetCode第80题删除有序数组中的重复项 II
    文章介绍了LeetCode第80题"删除有序数组中的重复项 II"的解法,利用双指针技术在O(1)空间复杂度内原地删除重复元素,并总结了双指针技术在处理有序数组问题中的应用。
    LeetCode第80题删除有序数组中的重复项 II
    LeetCode第26题删除有序数组中的重复项
    这篇文章介绍了LeetCode第26题"删除有序数组中的重复项"的解题方法,通过使用双指针技巧,高效地去除数组中的相邻重复元素。
    LeetCode第26题删除有序数组中的重复项
    |
    存储 Java API
    LeetCode------合并两个有序数组(4)【数组】
    这篇文章介绍了LeetCode上的"合并两个有序数组"问题,并提供了三种解法:第一种是使用Java的Arrays.sort()方法直接对合并后的数组进行排序;第二种是使用辅助数组和双指针技术进行合并;第三种则是从后向前的双指针方法,避免了使用额外的辅助数组。
    LeetCode------合并两个有序数组(4)【数组】
    |
    存储 算法 Java
    LeetCode经典算法题:打家劫舍java详解
    LeetCode经典算法题:打家劫舍java详解
    287 2