二叉树的遍历 &【NOIP2001普及组】& 洛谷 P1030 求先序排列
题目链接
https://www.luogu.org/problemnew/show/P1030
模板题
先讲一下二叉树的遍历
二叉树的遍历
- 分类
- 性质
- 求法
分为三类:
- 先序遍历(PreOrder):根节点→左子树→右子树
- 中序遍历(InOrder):左子树→根节点→右子树
- 后序遍历(PostOrder):左子树→右子树→根节点
我们可知:
- **序遍历实际上是指根节点的位置
- 无论哪种遍历顺序,左子树都在右子树的前面
- 在前序遍历中,第一个点是根节点
- 在后序遍历中,最后一个点是根节点
例如这样一个二叉树:

它的先序遍历:A--B--D--E--X--C--F--Y--Z
它的中序遍历:D--B--X--E--A--Y--F--Z--C
它的后序遍历:D--X--E--B--Y--Z--F--C--A
求后序遍历
用到递归的思想,求整个二叉树的后序遍历就是求每个子树的后序遍历,最后连接起来即可。
#include<iostream>
using namespace std;
string z,q;
int len,cnt;
void PostOrder(int l,int r){//求中序遍历中l到r这个子树的后序遍历
if(l>r) return; //边界条件
int i;
char ans=q[cnt++]; //先序遍历的第一个是根节点
for(i=l;i<=r;i++){
if(z[i]==ans) break;//找到根节点在中序遍历中的位置
}
PostOrder(l,i-); //递归左子树
PostOrder(i+,r); //递归右子树
cout<<ans; //注意后序遍历是左右根的顺序,所以最后输出根
}
int main()
{
cin>>z>>q; //z是中序遍历,q是先序遍历
len=z.length()-;
PostOrder(,z.length()-);//一开始是整个子树
return ;
}
求先序遍历
这比求后序遍历稍微有些复杂,需要保留根节点,即:PreOrder(左端点,右端点,根节点)。这是因为根节点在先序遍历中是从前往后排列的,而在后序遍历中不是这样的。
还是这个图:

它的先序遍历:A--B--D--E--X--C--F--Y--Z
它的中序遍历:D--B--X--E--A--Y--F--Z--C
它的后序遍历:D--X--E--B--Y--Z--F--C--A
在先序遍历中,根节点依次是A,B,D,E,X……是按照从前往后的顺序排列的,所以可以直接 ans=q[cnt++]; 而在后序遍历中却不是这样。
有人或许会说:那后序遍历中根节点是从后往前排列的,其实这是一个错误的结论。还是看这一个二叉树,后序遍历是A,C,F,Z,Y,B……显然是按照根→右子树→左子树排列的,而我们求的先序排列是根→左→右,显然这种方法不行。
所以我们需要多传一个参数,来记录根节点在后序遍历中的位置。重点:确定子树的根节点在后序遍历中的位置。
#include<iostream>
using namespace std;
string z,h;
int len;
void PreOrder(int l,int r,int root){//求中序遍历中l到r这个子树(以root为根)的后序遍历
if(l>r) return;
int i;
for(i=l;i<=r;i++){ //和求后序遍历一样
if(z[i]==h[root]) break;
}
cout<<h[root]; //注意是根左右
PreOrder(l,i-,root-(r-i)-);//左子树的根节点就是原来根节点减去右子树的节点数的上一个(r-i就是右子树的节点数)
PreOrder(i+,r,root-); //右子树的根节点就是后序遍历中原来根节点的上一个
}
int main()
{
cin>>z>>h;
len=h.length()-;
PreOrder(,z.length()-,len);
return ;
}
而在知道先序遍历和后序遍历的情况下,中序遍历是不唯一的,但可以求出情况数(后面将做补充)。
//NOIP2001普及组t3
二叉树的遍历 &【NOIP2001普及组】& 洛谷 P1030 求先序排列的更多相关文章
- 洛谷 P1030 求先序排列 Label:None
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...
- 洛谷P1030求先序排列
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度≤8. 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序排列. 输 ...
- 洛谷 P1030 求先序排列
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...
- 洛谷——P1030 求先序排列
https://www.luogu.org/problem/show?pid=1030#sub 题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度< ...
- 洛谷:P1087 FBI树 P1030 求先序排列 P1305 新二叉树
至于为啥把这三个题放到一起,大概是因为洛谷的试炼场吧,三道树的水题,首先要理解 先序中序后序遍历方法. fbi树由于数量小,在递归每个区间时,暴力跑一遍区间里的数,看看是否有0和1.至于递归的方法,二 ...
- P1030 求先序排列 /// 二叉树的遍历
题目大意: 给一棵树的中序排列 后序排列,求这棵树的先序排列 https://www.luogu.org/problemnew/show/P1030 二叉树的四种遍历解说 几种遍历的递归实现 后序排列 ...
- P1030 求先序排列 P1305 新二叉树
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度\le 8≤8). 输入输出格式 输入格式: 22行,均为大写字母组成的字符串,表示一棵二叉树的中序与 ...
- [NOIP2001] 提高组 洛谷P1027 Car的旅行路线
题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个 矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路,第I个城市中高速铁路了的单 ...
- [NOIP2001] 提高组 洛谷P1026 统计单词个数
题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保 证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的 ...
随机推荐
- 【272】ArcPy处理数据
参考:ArcPy 函数列表(按字母顺序) 参考:在arcgis上用python脚本(arcpy)做数据批处理 1. 导入 ArcPy,定义 Workspace >>> import ...
- 每天一道算法题(24)——自定义幂函数pow
double myPower(double base, int exponent){ if(exponent==0) return 1; if(exponent==1) return base; if ...
- 使用ffmpeg转换视频格式
命令: ffmpeg -i infile -ab 128 -acodec libmp3lame -ac 1 -ar 22050 -r 29.97 -qscale 6 -y outfile 说明: ...
- 容器控件JPanel的使用
-----------------siwuxie095 工程名:TestUI 包名:com.siwuxie095.ui 类名:TestPanel.java 工程结构目录如下: 在默认窗体 JFrame ...
- Python 网络爬虫 004 (编程) 如何编写一个网络爬虫,来下载(或叫:爬取)一个站点里的所有网页
爬取目标站点里所有的网页 使用的系统:Windows 10 64位 Python语言版本:Python 3.5.0 V 使用的编程Python的集成开发环境:PyCharm 2016 04 一 . 首 ...
- c++ 拷贝构造函数 继承
拷贝构造函数要求把所有变量都需要做拷贝.在有继承关系情况先,子类的拷贝构造函数,需要调用父类拷贝构造函数.示例代码如下: class Base{ public: virtual ~Base(); Ba ...
- Luogu 2470 [SCOI2007]压缩
和Luogu 4302 [SCOI2003]字符串折叠 差不多的想法,区间dp 为了计算方便,我们可以假设区间[l, r]的前面放了一个M,设$f_{i, j, 0/1}$表示区间$[i, j]$中是 ...
- C++面试笔记--单链表
1.编程实现单链表删除节点. 解析:如果删除的是头节点,如下图: 则把head指针指向头节点的下一个节点.同时free p1,如下图所示: 如果删除的是中间节点,如下图所示: 则用p2的n ...
- 关于redis-windows环境下的一些配置:
如果报错: The Windows version of Redis allocates a memory mapped heap for sharing with the forked proces ...
- ASP.NET MVC之"重定向/页面跳转"(关键词RedirectToAction,Redirect)
MVC5 API(官方) 1.RedirectToRouteResult RedirectToAction(string actionName); RedirectToRouteResult Redi ...