zoukankan      html  css  js  c++  java
  • 72_leetcode_Construct Binary Tree from Preorder and Inorder Traversal

    Given preorder and inorder traversal of a tree, construct the binary tree.

    Note:

    You may assume that duplicates do not exist in the tree.

    1:注意特殊情况。2:递归的情况;3:递归结束情况;4:首先获得根节点,之后把两个数组分别分成两部分,递归分别得出左子树和右子树。

        TreeNode *buildTree(vector<int> &preorder, vector<int> &inorder)
        {
            if(preorder.size() == 0 || inorder.size() == 0 || preorder.size() != inorder.size())
            {
                return NULL;
            }
            
            int size = (int)preorder.size();
            
            return buildTreeCore(preorder, 0, inorder, 0, size);
        }
        
        TreeNode* buildTreeCore(vector<int> &preorder, int preStart,  vector<int> &inorder, int preIn, int length)
        {
            if(length == 1)
            {
                if(preorder[preStart] != inorder[preIn])
                {
                    return NULL;
                }
            }
            
            int rootValue = preorder[preStart];
            TreeNode *root = new TreeNode(rootValue);
            
            int i = 0;
            
            for(; i < length; i++)
            {
                if(inorder[preIn + i] == rootValue)
                {
                    break;
                }
            }
            
            if(i == length)
            {
                return NULL;
            }
            
            if(i > 0)
            {
                root->left = buildTreeCore(preorder, preStart + 1, inorder, preIn, i);
            }
            
            if(i < length - 1)
            {
                root->right = buildTreeCore(preorder, preStart + i + 1, inorder, preIn + i + 1, length - 1 - i);
            }
            
            
            return root;
        }



    版权声明:本文博主原创文章,博客,未经同意不得转载。

  • 相关阅读:
    zookeeper集群搭建2.7
    hadoop集群环境搭建
    Kettle(6.0) 参数方式连接数据库
    kettle数据同步的5中方案
    kettle 合并记录步骤中的 关键字段和 比较字段的说明
    KETTLE常见问题和优化
    Hbase与Oracle的比较
    EHCache
    hdu2014 青年歌手大奖赛_评委会打分【C++】
    hdu2013 蟠桃记【C++】
  • 原文地址:https://www.cnblogs.com/zfyouxi/p/4909119.html
Copyright © 2011-2022 走看看