leetcode-将有序数组转换为二叉搜索树

108. 将有序数组转换为二叉搜索树

二叉搜索树的定义:

首先它是有序树

  • 若其左子树不空,则左子树上所有节点的值均小于它的根节点的值
  • 若其右子树不空,则右子树上所有节点的值均大于它的根节点的值
  • 它的左、右子树也分别为二叉搜索树

此题的题目中还强调了一点,高度平衡,这就需要知道平衡二叉树的概念:

  • 左子树和右子树的高度之差的绝对值不超过1
  • 左右子树都是平衡二叉树
  • 左右子树都是二叉搜索树
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]:
        def traversal(nums, left, right):
            if left > right:
                return None
            mid = (left + right) // 2
            root = TreeNode(nums[mid])
            root.left = traversal(nums, left, mid - 1)
            root.right = traversal(nums, mid + 1, right)
            return root
        root = traversal(nums, 0, len(nums) - 1)
        return root
相关推荐
songx_9943 分钟前
leetcode29( 有效的括号)
java·数据结构·算法·leetcode
东方芷兰3 小时前
Leetcode 刷题记录 21 —— 技巧
java·算法·leetcode·职场和发展·github·idea
爱编程的化学家7 小时前
代码随想录算法训练营第六天 - 哈希表2 || 454.四数相加II / 383.赎金信 / 15.三数之和 / 18.四数之和
数据结构·c++·算法·leetcode·双指针·哈希
芒克芒克14 小时前
LeetCode 面试经典 150 题:多数元素(摩尔投票法详解 + 多解法对比)
算法·leetcode·面试
ゞ 正在缓冲99%…16 小时前
leetcode438.找到字符串中所有字母异位词
leetcode·滑动窗口
pzx_00116 小时前
【LeetCode】392.判断子序列
算法·leetcode·职场和发展
iナナ19 小时前
Java优选算法——二分查找
数据结构·算法·leetcode
Adorable老犀牛21 小时前
阿里云-基于通义灵码实现高效 AI 编码 | 8 | 上手实操:LeetCode学习宝典,通义灵码赋能算法高效突破
学习·算法·leetcode
林木辛1 天前
LeetCode 热题 160.相交链表(双指针)
算法·leetcode·链表
崎岖Qiu1 天前
leetcode380:RandomizedSet - O(1)时间插入删除和获取随机元素(数组+哈希表的巧妙结合)
java·数据结构·算法·leetcode·力扣·散列表