LeetCode108给你一个整数数组nums,其中元素已经按升序排列,请你将其转换为一棵高度平衡二叉搜索树。
高度平衡二叉树是一棵满足「每个节点的左右两个子树的高度差的绝对值不超过1」的二叉树。
示例1:
输入:nums=[-16,-3,0,5,9]
输出:[6,-3,9,-16,nu11,5]
解释:[0,-16,5,nu11,-3,nu11,9]也将被视为正确答案:
class Solution {
public TreeNode sortedArrayToBST(int[] nums) {
return helper(nnums, 0, nums.length - 1);
}
public TreeNode helper(int[] nums, int left, int right) {
if (left > right) {
return null;
}
// 总是选择中间位置左边的数字作为根节点
int mid = (left + right) / 2;
TreeNode root = new TreeNode(nums[mid]);
root.left = helper(nums, left, mid - 1);
root.right = helper(nums, mid + 1, right);
return root;
}
}
将一个有序数组转化为二叉搜索树
总是选择中间位置左边的数字作为根节点
利用递归解决