力扣热门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;
    }
}
相关推荐
MediaTea几秒前
AI 术语通俗词典:召回率(分类)
人工智能·算法·机器学习·分类·数据挖掘
ECT-OS-JiuHuaShan1 分钟前
哲学的本质,是递归因果
java·开发语言·人工智能·科技·算法·机器学习·数学建模
_深海凉_8 分钟前
LeetCode热题100-26. 删除有序数组中的重复项
python·算法·leetcode
睡觉就不困鸭26 分钟前
第14天 四数之和
数据结构·算法
云泽80840 分钟前
二叉树高阶笔试算法题精讲(一):序列化、层序遍历、LCA 与 BST 转换
数据结构·c++·算法
再卷也是菜1 小时前
算法提高篇(3)线段树(下)
算法
嘻嘻哈哈樱桃1 小时前
牛客经典101题题解集--二叉树
java·数据结构·python·算法·leetcode·职场和发展
6Hzlia1 小时前
【Hot 100 刷题计划】 LeetCode 98. 验证二叉搜索树 | C++ 指针边界法
c++·算法·leetcode
AI科技星1 小时前
算子数学|独立完整学科章节(百条原创公式· ROOT传世定稿)
大数据·算法·机器学习·数学建模·数据挖掘·量子计算
斯维赤1 小时前
每天学习一个小算法:堆排序
学习·算法·排序算法