将一个按照升序排列的有序数组,转换为一棵高度平衡二叉搜索树。
本题中,一个高度平衡二叉树是指一个二叉树每个节点 的左右两个子树的高度差的绝对值不超过 1。
示例:
给定有序数组: [-10,-3,0,5,9], 一个可能的答案是:[0,-3,9,-10,null,5],它可以表示下面这个高度平衡二叉搜索树: 0 / \ -3 9 / / -10 5
解题思路:
建立二叉平衡树,保证左右子树的高度差值小于等于一,只需保证在有序数组中每次选择中间节点做为根节点即可。
public static TreeNode sortedArrayToBST(int[] nums) {
if(nums==null||nums.length==0)
return null;
else {
return solve(nums,0,nums.length-1);
}
}
private static TreeNode solve(int[] nums, int start, int end) {
// TODO Auto-generated method stub
if(start>end)
return null;
int mid=(start+end)/2;
TreeNode root=new TreeNode(nums[mid]);
root.left=solve(nums, start, mid-1);
root.right=solve(nums, mid+1, end);
return root;
}