7-9 根据后序和中序遍历输出先序遍历 (10 分)

简介: 7-9 根据后序和中序遍历输出先序遍历 (10 分)

7-9 根据后序和中序遍历输出先序遍历 (10 分)


本题要求根据给定的一棵二叉树的后序遍历和中序遍历结果,输出该树的先序遍历结果。


输入格式:


第一行给出正整数N(≤30),是树中结点的个数。随后两行,每行给出N个整数,分别对应后序遍历和中序遍历结果,数字间以空格分隔。题目保证输入正确对应一棵二叉树。


输出格式:


在一行中输出Preorder: 以及该树的先序遍历结果。数字间有1个空格,行末不得有多余空格。


输入样例:


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


结尾无空行


输出样例:


Preorder: 4 1 3 2 6 5 7


结尾无空行


#include<iostream>
using namespace std;
const int N=40;
int n,index;
int post[N],in[N],pre[N];
void dfs(int root,int l,int r){
    if(l>r)return ;
    int i=l;
    while(i<r&&in[i]!=post[root])i++;
    pre[index++]=post[root];
    dfs(root-(r-i+1),l,i-1);
    dfs(root-1,i+1,r);
}
int main(){
    cin>>n;
    for(int i=0;i<n;i++)cin>>post[i];
    for(int i=0;i<n;i++)cin>>in[i];
    printf("Preorder:");
    dfs(n-1,0,n-1);
    for(int i=0;i<n;i++)printf(" %d",pre[i]);
    return 0;
}







目录
相关文章
排序二叉树的创建及先序、中序、后序输出二叉树
排序二叉树的创建及先序、中序、后序输出二叉树
87 1
|
8月前
|
Java C++ 索引
leetcode-106:从中序与后序遍历序列构造二叉树
leetcode-106:从中序与后序遍历序列构造二叉树
55 0
|
8月前
|
存储
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
二叉树详解(深度优先遍历、前序,中序,后序、广度优先遍历、二叉树所有节点的个数、叶节点的个数)
|
3月前
|
存储 索引 Python
从中序与后序遍历序列构造二叉树
【10月更文挑战第13天】这段内容介绍了一种基于中序和后序遍历序列构建二叉树的方法。通过识别后序遍历中的根节点,并利用中序遍历划分左右子树,进而递归构建整棵树。文中提供了具体示例及Python代码实现,并分析了该方法的时间与空间复杂度。
117 0
|
3月前
输入二叉树先序序列,输出先序,中序,后序序列
输入二叉树先序序列,输出先序,中序,后序序列
28 0
21_从中序与后序遍历序列构造二叉树
21_从中序与后序遍历序列构造二叉树
|
C++ 索引
从中序与后序遍历序列构造二叉树(C++实现)
从中序与后序遍历序列构造二叉树(C++实现)
88 1
|
存储 算法 C++
【二叉树】利用前序和中序遍历结果生成二叉树并输出其后序和层序遍历结果
【二叉树】利用前序和中序遍历结果生成二叉树并输出其后序和层序遍历结果
165 0
|
C++
力扣 - 106、从中序与后序遍历序列构造二叉树
力扣 - 106、从中序与后序遍历序列构造二叉树
106 0
|
算法
【算法】二叉排序树:创建二叉树,并以中序遍历输出
【算法】二叉排序树:创建二叉树,并以中序遍历输出
226 0