题目链接
题目描述
给你一个整数数组 nums ,其中元素已经按 升序 排列,请你将其转换为一棵 高度平衡 二叉搜索树。
高度平衡 二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过 1 」的二叉树。
示例
示例1:
输入:nums = [-10,-3,0,5,9] 输出:[0,-3,9,-10,null,5] 解释:[0,-10,5,null,-3,null,9] 也将被视为正确答案:
提示
1 <= nums.length <= 10-10 <= nums[i] <= 10-
思路
中序遍历
要求高度平衡,因此我们需要将根节点建立在数组的中间(这个的正确性是可以证明的,有时间补充上),根据数组大小的奇偶性,可能有多种答案。
题解
# Definition for a binary tree node.# class TreeNode:# def __init__(self, val=0, left=None, right=None):# self.val = val# self.left = left# self.right = rightclass Solution:def sortedArrayToBST(self, nums: List[int]) -> TreeNode:def built(left, right):if left > right:return Nonemid = (left+right)//2root = TreeNode(nums[mid])root.left = built(left, mid-1)root.right = built(mid+1, right)return rootreturn built(0, len(nums)-1)
复杂度分析
时间复杂度:
- 空间复杂度:
,递归栈的深度。

