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

目录


一、题目

给你一个整数数组 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 按 严格递增 顺序排列


二、解法

因为数组严格递增,所以每次将中点拿出来,变成一个节点,然后再递归的往左右两边探寻


完整代码

python 复制代码
# 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 = right
class Solution:
    def sortedArrayToBST(self, nums: List[int]) -> Optional[TreeNode]:
        if len(nums) == 0:
            return None
        mid = len(nums) // 2
        node = TreeNode(nums[mid])
        node.left = self.sortedArrayToBST(nums[ : mid])
        node.right = self.sortedArrayToBST(nums[mid + 1: ])
        return node

相关推荐
奋进的小暄18 分钟前
数据结构(java)栈与队列
java·开发语言·数据结构
笺上山河梦1 小时前
文件操作(二进制文件)
开发语言·c++·学习·算法
大慕慕好懒2 小时前
PHP弱类型hash比较缺陷
算法·哈希算法
snowfoootball2 小时前
最短路问题
数据结构·算法
怀旧,3 小时前
【数据结构】4.单链表实现通讯录
android·服务器·数据结构
有你的冬天1983 小时前
数据结构(一)
数据结构·算法
满怀10153 小时前
【Python进阶】列表:全面解析与实战指南
python·算法
purrrew4 小时前
【数据结构_9】栈和队列
数据结构
爱学习的uu4 小时前
决策树:ID3,C4.5,CART树总结
算法·决策树·机器学习
wuqingshun3141594 小时前
蓝桥杯 9. 九宫幻方
数据结构·c++·算法·职场和发展·蓝桥杯·深度优先