您的位置:首页 > 其它

LeetCode-Convert Sorted Array to Binary Search Tree

2015-08-14 21:16 302 查看
Given an array where elements are sorted in ascending order, convert it to a height balanced BST.

主要步骤为:

1、取Middle为根节点

2、前半段递归为left节点

3、后半段递归为right节点

很明显遍历树的变体,上代码:

public TreeNode sortedArrayToBST(int[] nums) {
if (nums == null || nums.length == 0) return null;
return sortedArrayToBST(nums, 0, nums.length-1);
}

private TreeNode sortedArrayToBST(int[] nums, int s, int e) {
if (s > e) return null;
int mid = (s+e)/2;
TreeNode root = new TreeNode(nums[mid]);
root.left = sortedArrayToBST(nums, s, mid-1);
root.right = sortedArrayToBST(nums, mid+1, e);
return root;
}


私以为,代码还是挺美的!!!
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: