zoukankan      html  css  js  c++  java
  • Leetcode#106 Construct Binary Tree from Inorder and Postorder Traversal

    原题地址

    二叉树基本操作

    [       ]O[              ]

    [       ][              ]O

    代码:

     1 TreeNode *restore(vector<int> &inorder, vector<int> &postorder, int ip, int pp, int len) {
     2   if (len == 0)
     3     return NULL;
     4 
     5   TreeNode *node = new TreeNode(postorder[pp + len - 1]);
     6 
     7   if (len == 1)
     8     return node;
     9 
    10   int leftLen = 0;
    11   while (inorder[ip + leftLen] != postorder[pp + len - 1])
    12     leftLen++;
    13   node->left = restore(inorder, postorder, ip, pp, leftLen);
    14   node->right = restore(inorder, postorder, ip + leftLen + 1, pp + leftLen, len - leftLen - 1);
    15 
    16   return node;
    17 }
    18 
    19 TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder) {
    20   return restore(inorder, postorder, 0, 0, inorder.size());
    21 }
  • 相关阅读:
    ToString 格式化数值
    肾积水
    十月一日
    9月27日 星期六
    080929 气温骤降
    東京の空
    9月26日 星期五
    9月30日 星期二
    粉蓝房子&电影
    080922 雨
  • 原文地址:https://www.cnblogs.com/boring09/p/4261502.html
Copyright © 2011-2022 走看看