力扣热门100题之将有序数组转为二叉搜索树

升序数组 转换成一棵**高度平衡二叉搜索树(AVL)**平衡定义:每个节点的左右子树高度差不超过 1。

为什么取中间?

  • 数组升序
  • 中间值作为根,左边一半都更小,右边一半都更大
  • 左右子树节点数量几乎一样 → 天然平衡

这一步是这道题的灵魂。

  • 用中间数字创建一个节点
  • 它就是当前区间的树根

有序数组转平衡 BST = 递归分治 + 每次取中点做根

  • 中点保证平衡
  • 左小右大保证 BST
  • 递归自动建好整棵树

完整代码实现:

java 复制代码
class Solution {
    public TreeNode sortedArrayToBST(int[] nums) {
        return build(nums, 0, nums.length - 1);
    }
    private TreeNode build(int[] nums, int left, int right) {
        if (left > right) {
            return null;
        }

        int mid = (left + right) / 2; // 获取数组中点
        TreeNode root = new TreeNode(nums[mid]);

        root.left = build(nums, left, mid - 1);
        root.right = build(nums, mid + 1, right);

        return root;
    }
}
相关推荐
南境十里·墨染春水12 分钟前
讲讲移动语义
算法
西凉的悲伤21 分钟前
Guava类库——Range连续区间
java·算法·guava
菜菜的顾清寒21 分钟前
力扣HOT(100)54多维动态规划-最长公共子序列
算法·leetcode·动态规划
随意起个昵称26 分钟前
线性dp-LIS题目3(合唱队形)
算法
小六学编程31 分钟前
二分查找详解:从普通二分到左右边界
算法·c/c++
wayz1132 分钟前
Volume:PVO(百分比成交量震荡指标)技术指标详解
算法·金融·数据分析·量化交易·特征工程
毕竟是shy哥33 分钟前
PromptHash:基于亲和提示协同学习的自适应哈希检索跨模态算法
学习·算法·哈希算法
甄心爱学习33 分钟前
【项目实训(个人12)】
人工智能·python·算法
团象科技1 小时前
走访近百支出海技术团队后的海外云计算资源选型实操观察
大数据·人工智能·算法
勤自省1 小时前
吴恩达机器学习课程实验:线性回归模型入门(课后实验)
人工智能·算法·机器学习·回归·线性回归