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
相关推荐
一匹电信狗1 天前
【C++11】Lambda表达式+新的类功能
服务器·c++·算法·leetcode·小程序·stl·visual studio
在等晚安么1 天前
力扣面试150题打卡
算法·leetcode·面试
User_芊芊君子1 天前
【LeetCode经典题解】递归破解对称二叉树之谜
算法·leetcode·职场和发展
Rock_yzh1 天前
LeetCode算法刷题——49. 字母异位词分组
数据结构·c++·学习·算法·leetcode·职场和发展·哈希算法
小欣加油1 天前
leetcode 2654 使数组所有元素变成1的最少操作次数
数据结构·c++·算法·leetcode·职场和发展
Kt&Rs1 天前
11.12 LeetCode 题目汇总与解题思路
算法·leetcode
剪一朵云爱着1 天前
力扣81. 搜索旋转排序数组 II
算法·leetcode·职场和发展
im_AMBER1 天前
Leetcode 52
笔记·学习·算法·leetcode
小欣加油1 天前
leetcode 946 验证栈序列
c++·算法·leetcode·职场和发展