【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

相关推荐
pzx_00118 小时前
【LeetCode】14. 最长公共前缀
算法·leetcode·职场和发展
self_myth18 小时前
算法与数据结构实战技巧:从复杂度分析到数学优化
算法
songx_9919 小时前
leetcode10(跳跃游戏 II)
数据结构·算法·leetcode
先做个垃圾出来………20 小时前
差分数组(Difference Array)
java·数据结构·算法
hansang_IR20 小时前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乐迪信息20 小时前
乐迪信息:AI摄像机在智慧煤矿人员安全与行为识别中的技术应用
大数据·人工智能·算法·安全·视觉检测
多恩Stone20 小时前
【3DV 进阶-2】Hunyuan3D2.1 训练代码详细理解下-数据读取流程
人工智能·python·算法·3d·aigc
dragoooon3421 小时前
[数据结构——lesson5.1链表的应用]
数据结构·链表
惯导马工21 小时前
【论文导读】IDOL: Inertial Deep Orientation-Estimation and Localization
深度学习·算法
老姜洛克1 天前
自然语言处理(NLP)之n-gram从原理到实战
算法·nlp