108.将有序数组转换为二叉搜索树

思路

将有序数组转换为平衡二叉搜索树。递归方法,每次选取数组中间元素作为根节点,左侧子数组构建左子树,右侧子数组构建右子树。不断二分数组确保树的高度平衡,时间复杂度为O(n)。

代码

cpp 复制代码
class Solution {
private:
    TreeNode* traversal(vector<int>& nums,int l, int r) {
        if(l>r) return nullptr;
        int m=l+((r-l)/2);
        TreeNode* rr=new TreeNode(nums[m]);
        rr->left=traversal(nums,l,m-1);
        rr->right=traversal(nums,m+1,r);
        return rr;
    }
public:
    TreeNode* sortedArrayToBST(vector<int>& nums) {
        TreeNode* r=traversal(nums,0,nums.size()-1);
        return r;
    }
相关推荐
2401_8898846636 分钟前
高性能计算通信库
开发语言·c++·算法
郝YH是人间理想43 分钟前
Pandas库DataFrame数据结构
数据结构·pandas
不想看见4041 小时前
Hamming Distance位运算基础问题--力扣101算法题解笔记
算法
像污秽一样1 小时前
算法与设计与分析-习题4.1
算法·链表·排序算法
lhc200906251 小时前
【作业】 贪心算法
算法·贪心算法
天若有情6731 小时前
循环条件隐藏陷阱:我发现了「同循环双条件竞态问题」
c++·学习·算法·编程范式·while循环··竞态
j_xxx404_2 小时前
C++算法:前缀和与哈希表实战
数据结构·算法·leetcode
我能坚持多久2 小时前
【初阶数据结构07】——栈与队列的代码实现与解析
数据结构
We་ct2 小时前
LeetCode 22. 括号生成:DFS回溯解法详解
前端·数据结构·算法·leetcode·typescript·深度优先·回溯
mit6.8242 小时前
tabbi风波|开源协议
算法