题目链接

https://www.luogu.org/problemnew/show/P1030

模板题

先讲一下二叉树的遍历

二叉树的遍历

  • 分类
  • 性质
  • 求法

分为三类:

  1. 先序遍历(PreOrder):根节点→左子树→右子树
  2. 中序遍历(InOrder):左子树→根节点→右子树
  3. 后序遍历(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 求先序排列的更多相关文章

  1. 洛谷 P1030 求先序排列 Label:None

    题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...

  2. 洛谷P1030求先序排列

    题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度≤8. 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序排列. 输 ...

  3. 洛谷 P1030 求先序排列

    题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...

  4. 洛谷——P1030 求先序排列

    https://www.luogu.org/problem/show?pid=1030#sub 题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度< ...

  5. 洛谷:P1087 FBI树 P1030 求先序排列 P1305 新二叉树

    至于为啥把这三个题放到一起,大概是因为洛谷的试炼场吧,三道树的水题,首先要理解 先序中序后序遍历方法. fbi树由于数量小,在递归每个区间时,暴力跑一遍区间里的数,看看是否有0和1.至于递归的方法,二 ...

  6. P1030 求先序排列 /// 二叉树的遍历

    题目大意: 给一棵树的中序排列 后序排列,求这棵树的先序排列 https://www.luogu.org/problemnew/show/P1030 二叉树的四种遍历解说 几种遍历的递归实现 后序排列 ...

  7. P1030 求先序排列 P1305 新二叉树

    题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度\le 8≤8). 输入输出格式 输入格式: 22行,均为大写字母组成的字符串,表示一棵二叉树的中序与 ...

  8. [NOIP2001] 提高组 洛谷P1027 Car的旅行路线

    题目描述 又到暑假了,住在城市A的Car想和朋友一起去城市B旅游.她知道每个城市都有四个飞机场,分别位于一个 矩形的四个顶点上,同一个城市中两个机场之间有一条笔直的高速铁路,第I个城市中高速铁路了的单 ...

  9. [NOIP2001] 提高组 洛谷P1026 统计单词个数

    题目描述 给出一个长度不超过200的由小写英文字母组成的字母串(约定;该字串以每行20个字母的方式输入,且保 证每行一定为20个).要求将此字母串分成k份(1<k<=40),且每份中包含的 ...

随机推荐

  1. 【272】ArcPy处理数据

    参考:ArcPy 函数列表(按字母顺序) 参考:在arcgis上用python脚本(arcpy)做数据批处理 1. 导入 ArcPy,定义 Workspace >>> import ...

  2. 每天一道算法题(24)——自定义幂函数pow

    double myPower(double base, int exponent){ if(exponent==0) return 1; if(exponent==1) return base; if ...

  3. 使用ffmpeg转换视频格式

    命令: ffmpeg -i infile -ab 128 -acodec libmp3lame -ac 1 -ar 22050 -r 29.97 -qscale 6 -y outfile   说明: ...

  4. 容器控件JPanel的使用

    -----------------siwuxie095 工程名:TestUI 包名:com.siwuxie095.ui 类名:TestPanel.java 工程结构目录如下: 在默认窗体 JFrame ...

  5. Python 网络爬虫 004 (编程) 如何编写一个网络爬虫,来下载(或叫:爬取)一个站点里的所有网页

    爬取目标站点里所有的网页 使用的系统:Windows 10 64位 Python语言版本:Python 3.5.0 V 使用的编程Python的集成开发环境:PyCharm 2016 04 一 . 首 ...

  6. c++ 拷贝构造函数 继承

    拷贝构造函数要求把所有变量都需要做拷贝.在有继承关系情况先,子类的拷贝构造函数,需要调用父类拷贝构造函数.示例代码如下: class Base{ public: virtual ~Base(); Ba ...

  7. Luogu 2470 [SCOI2007]压缩

    和Luogu 4302 [SCOI2003]字符串折叠 差不多的想法,区间dp 为了计算方便,我们可以假设区间[l, r]的前面放了一个M,设$f_{i, j, 0/1}$表示区间$[i, j]$中是 ...

  8. C++面试笔记--单链表

    1.编程实现单链表删除节点.       解析:如果删除的是头节点,如下图: 则把head指针指向头节点的下一个节点.同时free p1,如下图所示: 如果删除的是中间节点,如下图所示: 则用p2的n ...

  9. 关于redis-windows环境下的一些配置:

    如果报错: The Windows version of Redis allocates a memory mapped heap for sharing with the forked proces ...

  10. ASP.NET MVC之"重定向/页面跳转"(关键词RedirectToAction,Redirect)

    MVC5 API(官方) 1.RedirectToRouteResult RedirectToAction(string actionName); RedirectToRouteResult Redi ...