您的位置:首页 > 职场人生

[LeetCode] Convert Sorted Array to Binary Search Tree

2014-01-04 11:40 441 查看
问题:

Given an array where elements are sorted in ascending order, convert it to a height balanced BST.

分析:

简单的一道递归题。

代码:

class Solution {
public:
TreeNode *sortedArrayToBST(const vector<int> &num, int start, int end) {
if (start > end) return 0;
if (start == end) return new TreeNode(num[start]);
int mid = (start + end) / 2;
TreeNode *root = new TreeNode(num[mid]);
root->left = sortedArrayToBST(num, start, mid - 1);
root->right = sortedArrayToBST(num, mid + 1, end);
return root;
}

TreeNode *sortedArrayToBST(vector<int> &num) {
int len = num.size();
if (len == 0) return 0;
if (len == 1) return (new TreeNode(num[0]));
return sortedArrayToBST(num, 0, len - 1);
}
};
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  leetcode 算法 面试