PAT甲级真题1020.树的遍历

yizhihongxing

翻译和代码思路:Acwing

一个二叉树,树中每个节点的权值互不相同。

现在给出它的后序遍历和中序遍历,请你输出它的层序遍历。

输入格式

第一行包含整数 N,表示二叉树的节点数。

第二行包含 N个整数,表示二叉树的后序遍历。

第三行包含 N 个整数,表示二叉树的中序遍历。

输出格式

输出一行 N个整数,表示二叉树的层序遍历。

数据范围

1<=N<=30

输入样例:

7
2 3 1 5 7 6 4
1 2 3 4 5 6 7

输出样例:

4 1 6 3 5 7 2

PAT甲级真题1020.树的遍历

#include<iostream>
#include<algorithm>
#include<cstring>
#include<vector>
using namespace std;
const int N=40;
int a[N],b[N],p[N];
int n;
vector<int> layer[N]; 
void Create(int al,int ar,int bl,int br,int d){
    if(al>ar) return;
    int val=a[ar];
    int k=p[val];   //当前递归中根节点的位置
    int numLeft=k-bl;  //左子树的结点树
    layer[d].push_back(val);
    Create(al,al+numLeft-1,bl,bl+numLeft,d+1);
    Create(al+numLeft,ar-1,k+1,br,d+1);
}
int main()
{
    cin>>n;
    for(int i=0;i<n;i++) cin>>a[i];
    for(int i=0;i<n;i++) cin>>b[i];
    for(int i=0;i<n;i++) p[b[i]]=i;  //记录中序遍历结点的位置
    Create(0,n-1,0,n-1,0);   //创建树
    for(int i=0;i<n;i++){
        for(auto x:layer[i]){
            cout<<x<<" ";
        }
    }
    return 0;
}

 

原文链接:https://www.cnblogs.com/yulianyi/p/17281471.html

本站文章如无特殊说明,均为本站原创,如若转载,请注明出处:PAT甲级真题1020.树的遍历 - Python技术站

(0)
上一篇 2023年4月17日
下一篇 2023年4月17日

相关文章

  • Python语言实现SIFT算法

    下面是详细讲解“Python语言实现SIFT算法”的完整攻略,包含两个示例说明。 SIFT算法 SIFT算法是一种用于图像特征提取和匹配的算法。它的基本思想是在图像中寻找关键点,并计算这些关键点的局部特征描述。这些特征描述符可以用于图像匹配、目标识别、三维重建等用。 SIFT算法的主要步骤包括: 尺度空间极值检测:在不同的尺度空间中寻找图中的极值点,用于确定…

    python 2023年5月14日
    00
  • python 数据挖掘算法的过程详解

    下面是关于“Python数据挖掘算法的过程详解”的完整攻略。 1. 数据挖掘算法的过程 数据挖掘算法的过程通常包括以下步骤: 1.1 数据预处理 数据预处理是数据挖掘算法第一步,它的目的是将原始数据转换为可用于分析的数据。数据预处理通常包括数据清洗、数据集、数据变换和数据规约等步骤。 1.2 特征选择 特征选择是数据挖掘算法的第二步,它的的是从原始数据中选择…

    python 2023年5月13日
    00
  • C语言实现通用数据结构之通用链表

    C语言是一门广泛应用于低级别系统编程的语言,也是数据结构和算法学习的重要工具之一,而在C语言中实现通用数据结构的方法之一就是通用链表。 通用链表是一种使用节点来组织数据的通用数据结构,每个节点包含一定量的数据以及指向链表中下一个节点的指针,因此,它可以用来实现许多不同的数据结构,例如栈、队列、树、图、哈希表等等。 具体实现通用链表的方法如下: 步骤一:定义节…

    数据结构 2023年5月17日
    00
  • Python机器学习k-近邻算法(K Nearest Neighbor)实例详解

    下面是详细讲解“Python机器学习k-近邻算法(KNearestNeighbor)实例详解”的完整攻略,包括算法原理、Python实现和两个示例说明。 算法原理 k-近邻算法是一种基于实例的学习方法,其主要思想是通过计算样本之间的距离,找到与目标样本最近的k个样本,然后根据这k个样本的类进行分类。k-近邻算法的实现过程如下: 计算目标样本与训练样本之间的距…

    python 2023年5月14日
    00
  • golang优先级队列的实现全过程

    下面是关于”golang优先级队列的实现全过程”的详细讲解。 什么是优先级队列? 优先级队列是一种常用的数据结构,它可以帮我们按照一定规则(即优先级)将元素按照大小排序,并支持快速插入、删除和查询最大或最小的元素等操作。我们可以将优先级队列想象成一个具有优先级的、自动排序的队列,其中优先级高的元素(比如数字大的元素)排在前面,优先级低的元素(比如数字小的元素…

    数据结构 2023年5月17日
    00
  • Python猜数字算法题详解

    下面是详细讲解“Python猜数字算法题详解”的完整攻略,包括算法原理、Python实现和两个示例说明。 算法原理 猜数字算法题是一种经典的算法题,其基本思想是通过二分查找的方式,逐步缩小猜测范围,最终猜中目标数字。具体实现过程如下: 首先确定猜测范围,通常为1到100之间的整数。 然后猜测中间的数字,即猜测范围的中间值。 根据猜测结果,如果猜中了目标数字,…

    python 2023年5月14日
    00
  • JavaScript数据结构和算法之二叉树详解

    JavaScript数据结构和算法之二叉树详解 什么是二叉树? 二叉树是一种树形结构,其中每个节点最多有两个子节点:左子节点和右子节点。每个节点都是一个对象,包括属性和方法。节点的属性可能包括值,左节点和右节点。节点的方法可能包括插入和删除。 二叉树的应用场景 二叉树的常用场景包括: 排序算法(二叉排序树); 表达式求值; 线段树; 图形图像学; 数据压缩算…

    数据结构 2023年5月17日
    00
  • Java队列数据结构的实现

    下面是实现Java队列数据结构的完整攻略。 Java队列数据结构的实现 1. 概述 队列是一种常用的线性数据结构,是“先进先出”(FIFO)的一种数据结构。队列通常具有两个操作:入队和出队,它们分别对应着在队列尾添加元素和在队列头删除元素的操作。 在Java中,有多种方式可以实现队列数据结构,本文将讲解两种常用的实现方式:基于数组的实现和基于链表的实现。 2…

    数据结构 2023年5月17日
    00
合作推广
合作推广
分享本页
返回顶部