【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());
    }
};
相关推荐
三毛的二哥1 小时前
BEV:典型BEV算法总结
人工智能·算法·计算机视觉·3d
南宫萧幕2 小时前
自控PID+MATLAB仿真+混动P0/P1/P2/P3/P4构型
算法·机器学习·matlab·simulink·控制·pid
浪浪小洋3 小时前
c++ qt课设定制
开发语言·c++
charlie1145141913 小时前
嵌入式C++工程实践第16篇:第四次重构 —— LED模板,从通用GPIO到专用抽象
c语言·开发语言·c++·驱动开发·嵌入式硬件·重构
handler013 小时前
Linux: 基本指令知识点(2)
linux·服务器·c语言·c++·笔记·学习
故事和你913 小时前
洛谷-数据结构1-4-图的基本应用1
开发语言·数据结构·算法·深度优先·动态规划·图论
我叫黑大帅3 小时前
为什么map查找时间复杂度是O(1)?
后端·算法·面试
炽烈小老头4 小时前
【每天学习一点算法 2026/04/20】除自身以外数组的乘积
学习·算法
skilllite作者4 小时前
AI agent 的 Assistant Auto LLM Routing 规划的思考
网络·人工智能·算法·rust·openclaw·agentskills
破浪前行·吴5 小时前
数据结构概述
数据结构·学习