重建二叉树

2020-07-29  本文已影响0人  Crazy_Bear
/**
 * Definition for binary tree
 * struct TreeNode {
 *     int val;
 *     TreeNode *left;
 *     TreeNode *right;
 *     TreeNode(int x) : val(x), left(NULL), right(NULL) {}
 * };
 */
class Solution {
public:
    TreeNode* reConstructBinaryTree(vector<int> pre,vector<int> vin) {

        int k  = 0;
        if(pre.empty()||vin.empty())
            return nullptr;
        TreeNode * node = new TreeNode(pre[0]);
        for(int i = 0; i < vin.size(); i++)
          if(pre[0] == vin[i]) {
              k = i;
              break;
          }
       /* for(int i = 0 ; i<k; i++)
        {
            vin_l.push_back(vin[i]);
            pre_l.push_back(pre[i+1]);
        }
         for(int i = k ; i<vin.size(); i++)
        {
            vin_r.push_back(vin[k]);
            pre_l.push_back(pre[i+1]);
        }*/
        vector<int> pre_l(pre.begin()+1, pre.begin() + k + 1);
        vector<int> pre_r(pre.begin()+ k + 1, pre.end());
        vector<int> vin_l(vin.begin(),vin.begin() + k);
        vector<int> vin_r(vin.begin() + k + 1,vin.end());
        node->left = reConstructBinaryTree(pre_l,vin_l);
        node->right = reConstructBinaryTree(pre_r,vin_r);
        return node;

    }
};
上一篇 下一篇

猜你喜欢

热点阅读