Q:给定一个已排序的数组,将它转换成一个平衡的二叉查找树。
A:Divide and conquer。为了达到一个平衡的二叉树,数组的中间元素做为root,然后对数组的左右两个部分分别生成新的子树,分别作为root的左右孩子。
时间复杂度:O(n)
空间复杂度:无额外开销
TreeNode *buildTree(vector<int> &num,int begin,int end) { if(begin<=end) { int middle = begin + (end - begin)/2; TreeNode *root = new TreeNode(num[middle]); root->left = buildTree(num,begin,middle-1); root->right = buildTree(num,middle+1,end); return root; }else return NULL; } TreeNode *sortedArrayToBST(vector<int> &num) { // Start typing your C/C++ solution below // DO NOT write int main() function return buildTree(num,0,num.size()-1); }
原文链接: https://www.cnblogs.com/summer-zhou/archive/2013/05/28/3103981.html
欢迎关注
微信关注下方公众号,第一时间获取干货硬货;公众号内回复【pdf】免费获取数百本计算机经典书籍
原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/90378
非原创文章文中已经注明原地址,如有侵权,联系删除
关注公众号【高性能架构探索】,第一时间获取最新文章
转载文章受原作者版权保护。转载请注明原作者出处!