题意
给予一个从小到大的数组, 构建一颗二叉平衡树, 即每个节点的两个子树的深度不能相差超过 1.
例 :
1 | 给予数组: [-10, -3, 0, 5, 9] |
解法
这道题有点类似于二分查找法, 即对二叉搜索树的反向推导, 每次取数组最中间的节点最为中节点, 左侧为左子树的内容, 右侧为右子树的内容, 直到不再存在子树.
1 | import util.TreeNode; |
Runtime: 0 ms, faster than 100.00% of Java online submissions for Convert Sorted Array to Binary Search Tree.
Memory Usage: 35.8 MB, less than 99.88% of Java online submissions for Convert Sorted Array to Binary