题目

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

Note:

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

分析

给定一颗二叉树的前序和中序遍历序列,求该二叉树。

我们手动做过很多这样的题目,掌握了其规则~

前序遍历第一个元素为树的root节点,然后在中序序列中查找该值,元素左侧为左子树,右侧为右子树; 求出左子树个数count,在前序序列中 , 除去第一个节点,接下来的count个元素构成左子树的前序序列,其余的构成右子树的前序序列。

开始,没有采用迭代器,声明vector占用了大量空间,Memory Limit Exceeded。。。

代码为:

/**
* Definition for a binary tree node.
* struct TreeNode {
* int val;
* TreeNode *left;
* TreeNode *right;
* TreeNode(int x) : val(x), left(NULL), right(NULL) {}
* };
*/
class Solution {
public:
TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
if (preorder.empty() && inorder.empty())
return NULL; //求树中节点个数
int size = preorder.size(); //先序遍历第一个节点为树的根节点
TreeNode *root = new TreeNode(preorder[0]); int pos = 0;
//在中序遍历结果中查找根节点
for (int i=0; i<size; ++i)
{
if (inorder[i] == preorder[0])
{
pos = i;
break;
}//if
}//for if (pos >= 0 && pos < size)
{
//则在inOrder中(0 , pos-1)为左子树中序遍历结果(pos+1,size-1)为右子树的中序遍历序列
//在preOrder中(1,pos)为左子树前序遍历结果(pos+1,size-1)为右子树前序遍历结果
vector<int> left_pre;
for (int j = 1; j <= pos; j++)
left_pre.push_back(preorder[j]); vector<int> left_in;
for (int j = 0; j < pos; ++j)
left_in.push_back(inorder[j]); root->left = buildTree(left_pre, left_in); //构造右子树
vector<int> right_pre , right_in;
for (int j = pos + 1; j < size; j++)
{
right_pre.push_back(preorder[j]);
right_in.push_back(inorder[j]);
} root->right = buildTree(right_pre, right_in);
}
return root;
}
};

然后,使用迭代器避免不必要的空间占用,AC~

AC代码

class Solution {
public: template <typename Iter>
TreeNode* make(Iter pre_begin, Iter pre_end, Iter in_begin, Iter in_end) { if (pre_begin == pre_end || in_begin == in_end)
return NULL; //先序遍历第一个节点为树的根节点
TreeNode *root = new TreeNode(*pre_begin); //在中序遍历结果中查找根节点
Iter iter = find(in_begin, in_end, *pre_begin); int count = iter - in_begin; if (iter != in_end)
{
//则在inOrder中(0 , pos-1)为左子树中序遍历结果(pos+1,size-1)为右子树的中序遍历序列
//在preOrder中(1,pos)为左子树前序遍历结果(pos+1,size-1)为右子树前序遍历结果 root->left = make(pre_begin + 1, pre_begin + count + 1, in_begin, iter); //构造右子树
root->right = make(pre_begin + count + 1, pre_end, iter + 1, in_end);
}
return root; } TreeNode* buildTree(vector<int>& preorder, vector<int>& inorder) {
if (preorder.empty() || inorder.empty())
return NULL; return make(preorder.begin(), preorder.end(), inorder.begin(), inorder.end());
}
};

GitHub测试程序源码

最新文章

  1. 时隔一年再读到the star
  2. Android请求服务器的两种方式--post, get的区别
  3. laravel 表单验证
  4. iOS字符串拆分
  5. Spring框架学习之第4节
  6. Oracle11g R2学习系列 之七安全性
  7. android 计时器,倒计时
  8. Android 系统自动重启Bug(高通平台)
  9. Thinkpad W520 + Ubuntu 12.04LTS, 13.10, 14.04LTS安装Nvidia显卡驱动设置
  10. H5的Web Audio Api
  11. Java中Integer和int的异同
  12. spring jar包依赖
  13. 3个问题:MySQL 中 character set 与 collation 的理解;utf8_general_ci 与 utf8_unicode_ci 区别;uft8mb4 默认collation:utf8mb4_0900_ai_ci 的含义
  14. [Spark SQL_1] Spark SQL 配置
  15. BZOJ.4072.[SDOI2016]征途(DP 斜率优化)
  16. Markdown中实时显示数学公式的方法
  17. Singleton 单例模式 MD
  18. 代理Servlet过滤器
  19. jeeplus中两个项目redis冲突问题
  20. [设计模式]JDK中的设计模式

热门文章

  1. Serega and Fun Codeforces - 455D || queue
  2. Bootstrap基础知识学习
  3. 公司开发部门GIT与SVN 之争
  4. Django中对单表的增删改查
  5. silverlight GPS监控,视频监控界面
  6. A*算法研究
  7. 闭包和OC的block的本质
  8. windows中安装模拟器后修改模拟器中的hosts方法
  9. PHP框架深度解析
  10. soapui测试https双向验证p12项目