LeetCode 热题 100_将有序数组转换为二叉搜索树(42_108_简单_C++)(二叉树;递归)

LeetCode 热题 100_将有序数组转换为二叉搜索树(42_108)

题目描述:

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

输入输出样例:

示例 1:

输入 :nums = [-10,-3,0,5,9]
输出 :[0,-3,9,-10,null,5]

解释 :[0,-10,5,null,-3,null,9] 也将被视为正确答案:
示例 2:

输入 :nums = [1,3]
输出 :[3,1]
解释:[1,null,3] 和 [3,1] 都是高度平衡二叉搜索树。

提示:

1 <= nums.length <= 104

-104 <= nums[i] <= 104

nums 按 严格递增 顺序排列

题解:

解题思路:

思路一(递归):

1、题目要求将元素已经按 升序 排列的数组转换为平衡 二叉搜索树,转换成平衡二叉树这里我们很容易能想到取之间元素,划分为两个子树,再取两个子树的中间元素,重复进行下去直至数组中的元素全部转换为平衡 二叉搜索树。
注意 :当前区间为偶数时如[1,2],选取1或2作为根节点都是可以的,本思路采用1作为根节点的方法。
力扣官方题解链接(官方给了以2作为根节点的情况和交替选取中间元素的情况)

2、复杂度分析:

① 时间复杂度:O(n),其中 n 是数组的长度。每个数字只访问一次

② 空间复杂度:O(logn),其中 n 是数组的长度。空间复杂度不考虑返回值,因此空间复杂度主要取决于递归栈的深度,递归栈的深度是 O(logn)。

代码实现

代码实现(递归):
cpp 复制代码
//将有序数组转换为二叉搜索树
TreeNode* sortedArrayToBST(vector<int>& nums) {
        return helper(nums,0,nums.size()-1);
    }
    TreeNode *helper(vector<int> nums,int left,int right){
    	//递归出口(划分的子区间无元素)
        if(left>right) return nullptr;
        //考虑越界问题
        int mid=left + (right - left)/2;
        //在向下递归的时候创建结点
        TreeNode *root=new TreeNode(nums[mid]);
        //在向上返回的时候连接结点
        root->left=helper(nums,left,mid-1);
        root->right=helper(nums,mid+1,right);
        
        return root;
    }
以思路一为例进行调试
cpp 复制代码
#include<iostream>
#include<vector>
using namespace std;

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* sortedArrayToBST(vector<int>& nums) {
        return helper(nums,0,nums.size()-1);
    }
    TreeNode *helper(vector<int> nums,int left,int right){
        if(left>right) return nullptr;
        //考虑数组越界的问题
        int mid=left + (right - left)/2;
        TreeNode *root=new TreeNode(nums[mid]);
        root->left=helper(nums,left,mid-1);
        root->right=helper(nums,mid+1,right);

        return root;
    }
    
	//中序遍历输出二叉树
    void inorder(TreeNode *root){
        if(root==nullptr) return;
        inorder(root->left);
        cout<<root->val<<" ";
        inorder(root->right);
    }
};

int main(){
    vector<int> nums={-10,-3,0,5,9};
    Solution s;
    //将有序数组转换为二叉搜索树
    TreeNode *root=s.sortedArrayToBST(nums);
    //中序遍历输出二叉树
    s.inorder(root);
    return 0;
}

LeetCode 热题 100_将有序数组转换为二叉搜索树(42_108)原题链接

欢迎大家和我沟通交流(✿◠‿◠)

相关推荐
强盛小灵通专卖员7 分钟前
分类分割详细指标说明
人工智能·深度学习·算法·机器学习
李匠20242 小时前
C++GO语言微服务之图片、短信验证码生成及存储
开发语言·c++·微服务·golang
IT猿手4 小时前
基于强化学习 Q-learning 算法求解城市场景下无人机三维路径规划研究,提供完整MATLAB代码
神经网络·算法·matlab·人机交互·无人机·强化学习·无人机三维路径规划
万能程序员-传康Kk7 小时前
旅游推荐数据分析可视化系统算法
算法·数据分析·旅游
PXM的算法星球7 小时前
【并发编程基石】CAS无锁算法详解:原理、实现与应用场景
算法
ll7788117 小时前
C++学习之路,从0到精通的征途:继承
开发语言·数据结构·c++·学习·算法
烨然若神人~7 小时前
算法第十七天|654. 最大二叉树、617.合并二叉树、700.二叉搜索树中的搜索、98.验证二叉搜索树
算法
爱coding的橙子7 小时前
每日算法刷题Day2 5.10:leetcode数组1道题3种解法,用时40min
算法·leetcode
我不想当小卡拉米7 小时前
【Linux】操作系统入门:冯诺依曼体系结构
linux·开发语言·网络·c++
炎芯随笔7 小时前
【C++】【设计模式】生产者-消费者模型
开发语言·c++·设计模式