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

题目描述

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

思路分析

思路描述

参考代码

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
func sortedArrayToBST(nums []int) *TreeNode {
	var build func(int, int) *TreeNode

	build = func(left, right int) *TreeNode {
		if left > right {
			return nil
		}

		// 选择中间节点作为根节点
		mid := left + (right-left)/2
		root := &TreeNode{Val: nums[mid]}

		// 构造左子树和右子树
		root.Left = build(left, mid-1)
		root.Right = build(mid+1, right)

		return root
	}

	return build(0, len(nums)-1)
}
  • 时间复杂度:O(n),每个元素访问一次。
  • 空间复杂度:O(log n),递归栈深度取决于树的高度,平衡 BST 的高度为 log n。

➡️ 点击查看 Java 题解

1
write your code here
本文作者:
本文链接: https://hgnulb.github.io/blog/2025/80396602
版权声明: 本博客所有文章除特别声明外,均采用 CC BY-NC-SA 4.0 许可协议,转载请注明出处!