题目链接:https://www.patest.cn/contests/gplt/L2-006

  1. 给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列。这里假设键值都是互不相等的正整数。
  2.  
  3. 输入格式:
  4.  
  5. 输入第一行给出一个正整数N(<=),是二叉树中结点的个数。第二行给出其后序遍历序列。第三行给出其中序遍历序列。数字间以空格分隔。
  6.  
  7. 输出格式:
  8.  
  9. 在一行中输出该树的层序遍历的序列。数字间以1个空格分隔,行首尾不得有多余空格。
  10. 输入样例:
  11.  
  12. 输出样例:

题意:给出一棵树的后序与中序遍历,输出层序遍历

方法:由中序遍历与后序遍历构建一棵树,再输出层序遍历

  1. #include<iostream>
  2. #include<stdio.h>
  3. #include<string.h>
  4. #include<stdlib.h>
  5. #include<stack>
  6. #include<vector>
  7. #include<string>
  8. #include<algorithm>
  9. #include<queue>
  10. using namespace std;
  11. const int N=;
  12. #define met(a,b) memset(a,b,sizeof(a))
  13. int a[N],b[N];
  14. int tree[N];
  15. int sum[N];
  16. void build(int n,int la,int ra,int lb,int rb)///利用递归的方法建立二叉树
  17. {
  18. if(ra<la ||rb<lb)
  19. return ;
  20. if(la==ra)
  21. {
  22. tree[n]=a[la];
  23. return ;
  24. }
  25. for(int i=la; i<=ra; i++)
  26. {
  27. if(a[i]==b[rb])///后序遍历的最右边的为根节点,找到根节点在中序遍历的位置,
  28. ///该位置的后边的点为左子树,后边为右之树,以这个原理递归下去
  29. {
  30. tree[n]=b[rb];
  31. build(*n,la,i-,lb,lb+i--la);
  32. build(*n+,i+,ra,lb+i-la,rb-);
  33. break;
  34. }
  35. }
  36. }
  37. void bfs(int s)
  38. {
  39. queue<int>Q;
  40. Q.push(s);
  41. int ans=;
  42. while(Q.size())
  43. {
  44. int y=Q.front();
  45. Q.pop();
  46. if(tree[y]==) continue;
  47. sum[ans++]=tree[y];
  48. Q.push(*y);
  49. Q.push(*y+);
  50. }
  51. }
  52. int main()
  53. {
  54. int n;
  55. met(tree,);
  56. scanf("%d",&n);
  57. for(int i=; i<=n; i++)
  58. {
  59. scanf("%d",&b[i]);
  60. }
  61. for(int i=; i<=n; i++)
  62. {
  63. scanf("%d",&a[i]);
  64. }
  65. build(,,n,,n);
  66. bfs();
  67. for(int i=;i<=n;i++)
  68. {
  69. printf("%d%c",sum[i],i==n?'\n':' ');
  70. }
  71. return ;
  72. }

(PAT)L2-006 树的遍历 (二叉树构建)的更多相关文章

  1. PTA L2-006 树的遍历-二叉树的后序遍历+中序遍历,输出层序遍历 团体程序设计天梯赛-练习集

    L2-006 树的遍历(25 分)   给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列.这里假设键值都是互不相等的正整数. 输入格式: 输入第一行给出一个正整数N(≤),是二叉树中结点的 ...

  2. PAT甲级专题|树的遍历

    PAT甲级专题-树的遍历 涉及知识点:树.建树.深度优先搜索.广度优先搜索.递归 甲级PTA 1004 输出每一层的结点,邻接表vector建树后.用dfs.bfs都可以边搜边存当前层的数据, #in ...

  3. GPTL—练习集—006树的遍历

    #include<bits/stdc++.h> using namespace std; typedef int daTp;//datatype typedef struct BTNode ...

  4. pat -1004(树的遍历)

    题目链接:https://pintia.cn/problem-sets/994805342720868352/problems/994805521431773184 思路: (1)用vector记录每 ...

  5. L2-006 树的遍历 (25 分) (根据后序遍历与中序遍历建二叉树)

    题目链接:https://pintia.cn/problem-sets/994805046380707840/problems/994805069361299456 L2-006 树的遍历 (25 分 ...

  6. javascript实现数据结构: 树和二叉树的应用--最优二叉树(赫夫曼树),回溯法与树的遍历--求集合幂集及八皇后问题

    赫夫曼树及其应用 赫夫曼(Huffman)树又称最优树,是一类带权路径长度最短的树,有着广泛的应用. 最优二叉树(Huffman树) 1 基本概念 ① 结点路径:从树中一个结点到另一个结点的之间的分支 ...

  7. PTA 7-10 树的遍历(二叉树基础、层序遍历、STL初体验之queue)

    7-10 树的遍历(25 分) 给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历的序列.这里假设键值都是互不相等的正整数. 输入格式: 输入第一行给出一个正整数N(≤30),是二叉树中结点的个数 ...

  8. pat L2-006. 树的遍历

    L2-006. 树的遍历 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 作者 陈越 给定一棵二叉树的后序遍历和中序遍历,请你输出其层序遍历 ...

  9. 团体程序设计天梯赛 L2-006. 树的遍历 L2-011. 玩转二叉树

    L2-006. 树的遍历 #include <stdio.h> #include <stdlib.h> #include <string.h> #include & ...

随机推荐

  1. Nunit的尝试

    (ps:没有代码,只有理论) 单元测试 单元测试(Unit Test)的一个测试用例(Test Case)是一小段代码,用于测试一个小的程序功能的行为是否正常,保证开发的功能子项能正确完成并实现其基本 ...

  2. Oracle day04 DML_事务_序列_视图_数据类型_DDL

    DMLinsert关键字作用:往表中插入一条(多条)数据 语法1:元祖值式的插入语法1: insert into tablename(column1,column2,...,columnN) valu ...

  3. rocketmq 发送时异常:system busy 和 broker busy 解决方案

    记一次 rocketmq 使用时的异常. 这里就不说什么rocketmq 源码啥的了,因为没看过.网上一搜这两个异常 大部分都是什么源码解读,也没说出现后的解决办法(蓝瘦香菇). 大量测试发现: 1. ...

  4. Spring boot入门(一):快速搭建Spring boot项目

    (一)Spring boot介绍 本部分摘自:https://www.zhihu.com/question/64671972/answer/223383505 Spring Boot是由Pivotal ...

  5. Java中的会话Cookie&&Session

    会话技术 会话: 一次会话中包含多次请求和响应. 一次会话:浏览器第一次给服务器资源发送请,会话建立,直到有一方断开为止 功能:在一次会话的范围内的多次请求之间共享数据 方式: 客户端会话技术:coo ...

  6. 【图解】FlexGrid Explorer 全功能问世

    前言 在去年的时候,我们推出了FlexGrid Demo,包含了FlexGrid的常用功能,如分组.滚动.冻结.自定义单元格类型.搜索面板.表格过滤器.树形结构.合并单元等,目前我们又在里面添加很多了 ...

  7. RecycleView设置顶部分割线(记录一个坑)

    大家都知道,想给RecycleView设置分割线可以重写RecyclerView.ItemDecoration 项目过程中,遇到一个需求:RecycleView顶部有一条灰色的间隔,我想到了给Recy ...

  8. Android 为TV端助力

    记录两次事情: 第一个给view添加动画效果,需要保证view是可以获取焦点的 第二个给listview,GridView设置选择器 listselector时,要保证他的子item无背景,否则选择器 ...

  9. po编程——自动化测试面试必问

    先来看一个在腾讯课堂首页搜索机构的操作步骤: 1:首先打开腾讯课堂的首页:https://ke.qq.com 2:点击课程或机构的下拉选择图标 3:选择机构 4:在搜索框输入要搜索的机构名称 5:点击 ...

  10. CentOS7安装MySQL并配置账户等

    注意: 有的Centos版本默认安装了mariadb, 可以先将其卸载 检查mariadb是否安装 yum list installed | grep mariadb 卸载mariadb( all ) ...