Convert Sorted Array to Binary Search Tree

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】免费获取数百本计算机经典书籍

    Convert Sorted Array to Binary Search Tree

原创文章受到原创版权保护。转载请注明出处:https://www.ccppcoding.com/archives/90378

非原创文章文中已经注明原地址,如有侵权,联系删除

关注公众号【高性能架构探索】,第一时间获取最新文章

转载文章受原作者版权保护。转载请注明原作者出处!

(0)
上一篇 2023年2月10日 上午12:36
下一篇 2023年2月10日 上午12:36

相关推荐