【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());
    }
};
相关推荐
8Qi85 分钟前
LeetCode 76. 最小覆盖子串(Minimum Window Substring)
数据结构·算法·leetcode·滑动窗口·哈希表
weixin_BYSJ19877 分钟前
springboot旅游管理系统04470(附源码+开发文档+部署教程)
java·spring boot·python·算法·django·flask·旅游
Bingorl8 分钟前
机器学习之朴素贝叶斯算法
人工智能·算法·机器学习
8Qi89 分钟前
LeetCode 209. 长度最小的子数组(Minimum Size Subarray Sum)
java·算法·leetcode·双指针·滑动窗口
小小de风呀14 分钟前
de风——【从零开始学 C++】(十)vector的模拟实现
开发语言·c++
爱和冰阔落28 分钟前
【Linux系统编程】环境变量深度解析——从 fork 继承到 export 内建命令,两张表打通进程上下文
linux·c++·环境变量·系统调用
流浪00130 分钟前
C++篇:深入理解 C++ 智能指针:从裸指针到 RAII 的蜕变
开发语言·c++
丘山望岳31 分钟前
二叉搜索双壁——map和set
开发语言·数据结构·c++
狮子座明仔32 分钟前
DeCoRL:把推理链拆成“乐团合奏“——AAAI 2026 一篇把 RLHF 推到 32B 打 GPT-4o 的工作
人工智能·深度学习·算法
QiLinkOS33 分钟前
合肥气链科技有限公司创办与未来技术应用
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法