当前位置:网站首页>LeetCode 0108. Convert an ordered array into a binary search tree - the median of the array is the root, and the left and right of the median are the left and right subtrees respectively
LeetCode 0108. Convert an ordered array into a binary search tree - the median of the array is the root, and the left and right of the median are the left and right subtrees respectively
2022-07-05 06:10:00 【Tisfy】
【LetMeFly】108. Convert an ordered array to a binary search tree - The value in the array is the root , The left and right median values are respectively left and right subtrees
Force button topic link :https://leetcode.cn/problems/convert-sorted-array-to-binary-search-tree/
Give you an array of integers nums
, Where elements have been Ascending array , Please turn it into a Highly balanced Binary search tree .
Highly balanced A binary tree is a tree that satisfies 「 The absolute value of the height difference between the left and right subtrees of each node does not exceed 1 」 Two fork tree .
Example 1:
data:image/s3,"s3://crabby-images/54889/54889886598ba9981204bfae78b8c8ef05768b07" alt=""
Input :nums = [-10,-3,0,5,9] Output :[0,-3,9,-10,null,5] explain :[0,-10,5,null,-3,null,9] Will also be considered the right answer :![]()
Example 2:
data:image/s3,"s3://crabby-images/80235/80235848b80155524edfdcc76d6630c5398b13e5" alt=""
Input :nums = [1,3] Output :[3,1] explain :[1,null,3] and [3,1] They're all highly balanced binary search trees .
Tips :
1 <= nums.length <= 104
-104 <= nums[i] <= 104
nums
Press Strictly increasing Sequential arrangement
In fact, I think it's good to set the difficulty of this question to medium
Method 1 : The value in the array is the root , The left and right median values are respectively left and right subtrees
seeing the name of a thing one thinks of its function , To make this tree a highly balanced binary search tree , We just need to take the median of the array as the root .
Because take the median of the array as the root , The number of elements on the left and right is equal ( Or one difference ) The effect of .
meanwhile , What the title gives is an array that has been sorted , Therefore, the elements on the left of the value in the array are all smaller than the median elements , All on the right are larger than .
Therefore, the left side of the median is regarded as the left subtree , All the right trees can be regarded as right subtrees .
This becomes a sub problem : Construction of left and right subtrees . So recursion is enough .
Termination conditions : The array to be built is empty .
- Time complexity O ( n ) O(n) O(n), among n n n Is the number of elements in the array .
- Spatial complexity O ( log n ) O(\log n) O(logn), Depending on the depth of the recursive stack .
AC Code
C++
class Solution {
private:
TreeNode* build(vector<int>& nums, int l, int r) {
if (l >= r)
return nullptr;
int mid = (l + r) >> 1;
TreeNode* root = new TreeNode(nums[mid]);
root->left = build(nums, l, mid);
root->right = build(nums, mid + 1, r);
return root;
}
public:
TreeNode* sortedArrayToBST(vector<int>& nums) {
return build(nums, 0, nums.size());
}
};
Synchronous posting on CSDN, Originality is not easy. , Reprint please attach Link to the original text Oh ~
Tisfy:https://letmefly.blog.csdn.net/article/details/125610878
边栏推荐
- leetcode-6111:螺旋矩阵 IV
- [rust notes] 16 input and output (Part 2)
- Spark中groupByKey() 和 reduceByKey() 和combineByKey()
- 【Rust 笔记】14-集合(上)
- QT判断界面当前点击的按钮和当前鼠标坐标
- 1041 Be Unique
- 2022 pole technology communication arm virtual hardware accelerates the development of Internet of things software
- js快速将json数据转换为url参数
- RGB LED infinite mirror controlled by Arduino
- One question per day 1765 The highest point in the map
猜你喜欢
Dichotomy, discretization, etc
[jailhouse article] look mum, no VM exits
leetcode-6108:解密消息
MatrixDB v4.5.0 重磅发布,全新推出 MARS2 存储引擎!
Navicat連接Oracle數據庫報錯ORA-28547或ORA-03135
Solution to game 10 of the personal field
Navicat连接Oracle数据库报错ORA-28547或ORA-03135
Individual game 12
[jailhouse article] performance measurements for hypervisors on embedded ARM processors
实时时钟 (RTC)
随机推荐
QQ电脑版取消转义符输入表情
Shutter web hardware keyboard monitoring
Some common problems in the assessment of network engineers: WLAN, BGP, switch
Introduction to convolutional neural network
Time of process
Overview of variable resistors - structure, operation and different applications
智慧工地“水电能耗在线监测系统”
Wazuh开源主机安全解决方案的简介与使用体验
redis发布订阅命令行实现
Flutter Web 硬件键盘监听
[rust notes] 16 input and output (Part 2)
CF1634 F. Fibonacci Additions
CF1637E Best Pair
927. Trisection simulation
Implement an iterative stack
Brief introduction to tcp/ip protocol stack
TypeScript 基础讲解
可变电阻器概述——结构、工作和不同应用
1.13 - RISC/CISC
Smart construction site "hydropower energy consumption online monitoring system"