算法-二叉树篇26-将有序数组转换为二叉搜索树

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

力扣题目链接

题目描述

给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 平衡 二叉搜索树。

解题思路

很简单的遇到递归题目,对数组取半,然后构建中间节点作为该数组对应的树,然后左右两边切割数组递归下去。

题解

复制代码
class Solution {
public:
    TreeNode* sortedArrayToBST(vector<int>& nums) {
        if(nums.size() == 0){
            return nullptr;
        }
        if(nums.size() == 1){
            TreeNode* temp = new TreeNode(nums[0]);
            return temp;
        }
        int n = nums.size() / 2;
        vector<int> arr1(nums.begin(), nums.begin() + n);
        vector<int> arr2(nums.begin() + n + 1, nums.end());
        TreeNode* temp = new TreeNode(nums[n]);
        temp->left = sortedArrayToBST(arr1);
        temp->right = sortedArrayToBST(arr2);

        return temp;
    }
};
相关推荐
凯瑟琳.奥古斯特5 小时前
力扣1235:加权区间调度最优解
java·python·算法·leetcode·职场和发展
耶叶5 小时前
餐厅出入最少人数问题:贪心算法
算法·贪心算法
gihigo19985 小时前
基于小波框架与稀疏表示的SAR图像目标识别系统(MATLAB实现)
算法
吴可可1235 小时前
CAD2004自定义实体开发环境配置
c++·算法
装不满的克莱因瓶5 小时前
矩阵的主成分是什么?主成分分析(PCA)又能做什么?
人工智能·线性代数·算法·机器学习·ai·矩阵·pca
大菜菜小个子5 小时前
template<typename T>使用
java·开发语言·算法
Fanfanaas6 小时前
C++ 继承
java·开发语言·jvm·c++·学习·算法
lqqjuly6 小时前
模型合并与融合:理论、算法与可运行实现—从损失曲面几何到多模型融合
算法
memcpy06 小时前
LeetCode 2144. 打折购买糖果的最小开销【贪心】
算法·leetcode·职场和发展
ID_180079054737 小时前
淘宝商品详情数据接口深度解析:架构、鉴权、数据结构与实战
数据结构·架构