力扣HOT100(46)将有序数组转换为二叉搜索树

平衡二叉树(全称:平衡二叉搜索树,也叫 AVL 树) = 一棵二叉搜索树 + 一个额外的平衡限制:

树中任意一个节点左子树高度右子树高度 的差的绝对值,不能超过 1。

简单说:整棵树不能 "歪得太厉害",左右两边的高度差不多

什么是 "二叉搜索树"?

你刚做的题就是这个,核心性质:

任意节点的左子树所有节点的值 都 < 该节点的值; 任意节点的右子树所有节点的值 都 > 该节点的值。

面试 100% 首选方法一:总是选择中间位置左边的数字作为根节点

核心思路(一句话讲透)

利用分治思想 :有序数组是二叉搜索树的中序遍历序列 ,要构建平衡二叉搜索树,只需要每次选数组中间的元素作为根节点,然后递归用左边的子数组构建左子树,右边的子数组构建右子树即可。

为什么选中间元素就能保证平衡?

  • 选中间元素后,左右子树的节点数最多相差 1,自然满足平衡二叉树 "左右子树高度差不超过 1" 的要求
cpp 复制代码
/**
 * Definition for a binary tree node.
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode() : val(0), left(nullptr), right(nullptr) {}
 *     TreeNode(int x) : val(x), left(nullptr), right(nullptr) {}
 *     TreeNode(int x, TreeNode *left, TreeNode *right) : val(x), left(left), right(right) {}
 * };
 */
class Solution {
public:

        //辅助函数 用nums中的[left,right]区间的元素构建平衡BST
    TreeNode* helper(vector<int>& nums,int left,int right){
        if(left > right){
            return nullptr;
        }

        int mid = (left + right) /2;
        TreeNode* root = new TreeNode(nums[mid]);

        //递归构建左子树:用左边的区间[left,mid-1]
        root->left = helper(nums,left,mid-1);
        //构建右子树
        root->right = helper(nums,mid+1,right);

        return root;
    }

    TreeNode* sortedArrayToBST(vector<int>& nums) {
        return helper(nums,0,nums.size()-1);
    }
};
相关推荐
JieE2121 天前
LeetCode 101. 对称二叉树|JS 递归 + 迭代双解法,彻底搞懂镜像判断
javascript·算法
JieE2122 天前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack202 天前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树3 天前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2123 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2123 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术3 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦3 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050734 天前
(一)小红的数组操作
算法·编程语言