【Leetcode热题100】108.将有序数组转换为二叉搜索树

108. 将有序数组转换为二叉搜索树 - 力扣(LeetCode)https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/description/?envType=study-plan-v2&envId=top-100-liked

思路

二叉搜索树(BST)的核心性质是:任意节点的左子树所有值 <该节点值 < 右子树所有值;

而 "高度平衡" 要求每个节点的左右子树高度差不超过 1。

解题过程

每次选取数组的中间元素作为当前子树的根节点(保证左右子树节点数量尽可能均衡,从而满足平衡要求);

递归地用左半部分数组构建左子树,右半部分数组构建右子树;直到数组区间为空时终止递归。

复杂度

时间复杂度: O (n)

空间复杂度: O (n)

核心代码

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:
    TreeNode* DFS(vector<int>& nums,int left,int right){
        if(left==right) return NULL;// 终止条件:左闭右开区间[left, right)为空,返回空节点
        int n=left+(right-left)/2;// 计算中间位置,避免left+right溢出,等价于(left+right)/2但更安全
        // 1. 以中间元素为根节点值
        // 2. 递归构建左子树(区间[left, n))
        // 3. 递归构建右子树(区间[n+1, right))
        return new TreeNode(nums[n],DFS(nums,left,n),DFS(nums,n+1,right));
    }
    
    TreeNode* sortedArrayToBST(vector<int>& nums) {
        // 初始调用DFS,处理整个数组(区间[0, nums.size()))
        return DFS(nums,0,nums.size());
    }
};
相关推荐
VelinX2 分钟前
【个人学习||算法】多维动态规划
学习·算法·动态规划
AlenTech4 分钟前
139. 单词拆分 - 力扣(LeetCode)
算法·leetcode·职场和发展
郭涤生9 分钟前
std::async 和 std::future的使用
c++
墨韵流芳17 分钟前
CCF-CSP第41次认证第一题——平衡数
c++·算法·ccf·平衡数
Book思议-26 分钟前
【数据结构实战】栈的经典应用:后缀表达式求值 +中缀转后缀 ,原理 + 代码双通透
数据结构·算法··后缀表达式·后缀转中缀
炽烈小老头28 分钟前
【 每天学习一点算法 2026/03/30】跳跃游戏
学习·算法
水饺编程36 分钟前
第4章,[标签 Win32] :SysMets3 程序讲解01
c语言·c++·windows·visual studio
m0_6265352038 分钟前
今日需要注意
数据结构
wuweijianlove1 小时前
算法性能预测的统计模型与参数敏感性分析的技术6
算法
Just right1 小时前
重学算法 数组 LC27移除元素
数据结构·算法