原题地址

思路:

leetcode105题差不多,这道题是给中序和后序,求出二叉树。

解法一:

思路和105题差不多,只是pos是从后往前遍历,生成树顺序也是先右后左。

  1. class Solution {
  2. public:
  3. TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder) {
  4. int pos = postorder.size() - 1;
  5. return dfs(inorder, postorder, 0, inorder.size(), pos);
  6. }
  7. private:
  8. TreeNode *dfs(vector<int> &inorder, vector<int> &postorder, int beg, int end,
  9. int &pos) {
  10. TreeNode *node = NULL;
  11. if (beg < end) {
  12. int i = 0;
  13. for (i = beg; i < end; ++i)
  14. if (postorder[pos] == inorder[i]) break;
  15. pos--;
  16. node = new TreeNode(inorder[i]);
  17. node->right = dfs(inorder, postorder, i + 1, end, pos);
  18. node->left = dfs(inorder, postorder, beg, i, pos);
  19. }
  20. return node;
  21. }
  22. };
解法二:

解法二是看了别人的题解入手的,和解法一不同思路的是对两个序都用一组beg和end来划分区间。

中序(beg,end)很好划分,假设mid指向当前节点的root值,则分为mid前一半和mid后一半。

后序(pbeg,pend)的划分,是mid - beg的这一段距离。

  1. class Solution
  2. {
  3. public:
  4. TreeNode *buildTree(vector<int> &inorder, vector<int> &postorder)
  5. {
  6. return dfs(inorder, postorder, 0, inorder.size(), 0, postorder.size());
  7. }
  8. private:
  9. TreeNode *dfs(vector<int> &inorder, vector<int> &postorder, int beg, int end,
  10. int pbeg, int pend)
  11. {
  12. TreeNode *node = NULL;
  13. if (beg < end)
  14. {
  15. int i = 0;
  16. for (i = beg; i < end; ++i)
  17. if (postorder[pend - 1] == inorder[i])
  18. break;
  19. node = new TreeNode(inorder[i]);
  20. node->left = dfs(inorder, postorder, beg, i, pbeg, pbeg + i - beg);
  21. node->right =
  22. dfs(inorder, postorder, i + 1, end, pbeg + i - beg, pend - 1);
  23. }
  24. return node;
  25. }
  26. };

解法一好理解,但是速度慢,用了16ms,击败46%

解法二难点在于理解后序区间划分的依据,用了12ms,击败78%

虽然做了105题,但是做这题还是花了一个半小时。

还是因为不够深入的理解原理,不能总是光看题解就过了。

[leetcode] 106. Construct Binary Tree from Inorder and Postorder Traversal(medium)的更多相关文章

  1. LeetCode 106. Construct Binary Tree from Inorder and Postorder Traversal (用中序和后序树遍历来建立二叉树)

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  2. Java for LeetCode 106 Construct Binary Tree from Inorder and Postorder Traversal

    Construct Binary Tree from Inorder and Postorder Traversal Total Accepted: 31041 Total Submissions: ...

  3. (二叉树 递归) leetcode 106. Construct Binary Tree from Inorder and Postorder Traversal

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  4. [LeetCode] 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍历建立二叉树

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  5. C#解leetcode 106. Construct Binary Tree from Inorder and Postorder Traversal

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  6. LeetCode 106. Construct Binary Tree from Inorder and Postorder Traversal 由中序和后序遍历建立二叉树 C++

    Given inorder and postorder traversal of a tree, construct the binary tree. Note:You may assume that ...

  7. Leetcode#106 Construct Binary Tree from Inorder and Postorder Traversal

    原题地址 二叉树基本操作 [       ]O[              ] [       ][              ]O 代码: TreeNode *restore(vector<i ...

  8. 【LeetCode】106. Construct Binary Tree from Inorder and Postorder Traversal 解题报告

    [LeetCode]106. Construct Binary Tree from Inorder and Postorder Traversal 解题报告(Python) 标签: LeetCode ...

  9. 【LeetCode】106. Construct Binary Tree from Inorder and Postorder Traversal

    Construct Binary Tree from Inorder and Postorder Traversal Given inorder and postorder traversal of ...

随机推荐

  1. 树莓派 Qt5.7交叉编译

    一.准备软件    1.2016-11-25-raspbian-jessie.img(官网下载)    2.cross-compile-tools-master.zip    3.gcc-4.7-li ...

  2. c# 9png实现(图片缩放)

    跟据9png的实现原理自己写了个生成图片的函数,9png的原理是将图片切成9块如下 其中1.3.7.9不进行缩放,2,4,5,6,8进行缩放,这样就防止了放大后导致边界出现锯齿的问题 在实现过程中主要 ...

  3. 管道Demo

    使用管道实现读取DOS命令结果,界面如下: 主要代码如下: UpdateData(TRUE); //创建一个管道,用于接收命令执行结果 SECURITY_ATTRIBUTES sa; ZeroMemo ...

  4. LFS Linux From Scratch 笔记(经验非教程)

    做了一个自己的DIY Linux系统.从编译每一行代码,建立每一个文件系统结构开始. 创造自己的GNU/Linux系统,不同于任何发行版.按照的教程是来自 linuxfromscratch.org 来 ...

  5. "犯罪心理"解读Mybatis拦截器

    原文链接:"犯罪心理"解读Mybatis拦截器 Mybatis拦截器执行过程解析 文章写过之后,我觉得 "Mybatis 拦截器案件"背后一定还隐藏着某种设计动 ...

  6. sentinel 滑动窗口统计机制

    sentinel的滑动窗口统计机制就是根据当前时间,获取对应的时间窗口,并更新该时间窗口中的各项统计指标(pass/block/rt等),这些指标被用来进行后续判断,比如限流.降级等:随着时间的推移, ...

  7. 关于C# 异步

    关于C# 异步操作整理 按照个人的理解, 写一个接口用Task异步操作(态度:接受并且学习,您提出宝贵的经验与理解,我会认真学习): 在主线程中调用异步方法,如果主线程依赖异步方法的返回值那么你一定会 ...

  8. PWN 菜鸡入门之 shellcode编写 及exploid-db用法示例

    下面我将参考其他资料来一步步示范shellcode的几种编写方式 0x01 系统调用 通过系统调用execve函数返回shell C语言实现: #include<unistd.h> #in ...

  9. 【mysql5.7】远程无法连接设置

    版本5.7 系统:ubuntu16.04 配置文件位置(apt安装): 1.链接设置 注释掉在/etc/mysql/mysql.conf.d/mysqld.cnf里面的bind-address = 1 ...

  10. Programming In Lua 第三章

    1, 2, 3, 4, 5,lua中,只有false和nil为假,0和空字符串为真. 6, 7,