力扣热门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;
    }
}
相关推荐
xiaoxiaoxiaolll9 小时前
金属结构疲劳寿命预测与健康监测技术
人工智能·算法·机器学习
故事和你919 小时前
洛谷-【图论2-1】树4
开发语言·数据结构·c++·算法·动态规划·图论
故事和你919 小时前
洛谷-【图论2-1】树1
开发语言·数据结构·c++·算法·深度优先·动态规划·图论
敲代码的嘎仔9 小时前
力扣高频SQL基础50题详解
开发语言·数据库·笔记·sql·算法·leetcode·后端开发
小虎牙0079 小时前
面试被问复杂度总懵?这篇指南帮你彻底搞清
算法
knight_9___11 小时前
大模型project面试4
人工智能·python·深度学习·算法·面试·agent
l1t11 小时前
DeepSeek总结的欢迎来到 ORDER BY 丛林
数据库·算法
谙弆悕博士11 小时前
【附C源码】二叉搜索树的C语言实现
c语言·开发语言·数据结构·算法·二叉树·项目实战·数据结构与算法
宵时待雨11 小时前
回溯算法专题2:二叉树中的深搜
开发语言·数据结构·c++·笔记·算法·深度优先
刀法如飞11 小时前
JavaScript 数组去重的 20 种实现方式,学会用不同思路解决问题
前端·javascript·算法