题解 P1030 【求先序排列】
题解 P1030 【求先序排列】
旧题新解~
今天做这个题,发现还是没有AC,于是滚回来用了一大堆数据结构A了这个题目,好像复杂度还挺高......
#include <iostream>
#include <cstdio>
#include <stack>
#include <cstring>
#include <map>
#include <algorithm>
using namespace std;
char mid[101],late[101];
int mid_[101],late_[101],len=0;
struct tree{
tree *lson,*rson;
int ch;
}rt_,*rt=&rt_;
map<int,char>ic;
map<char,int>ci;
stack<char>qwq;
void build(int ch,tree *root);
inline void clear_(tree *root);
void print1(tree *root);
int main()
{
clear_(rt);
scanf("%s%s",mid,late);
len=strlen(mid);
for (register int i=0;i<len;i++)
{
ic.insert(make_pair(i+1,mid[i]));
ci.insert(make_pair(mid[i],i+1));
}
for (register int i=0;i<len;i++)
{
late_[i]=ci[late[i]];
}
reverse(late_,late_+len);
for (register int i=0;i<len;i++)
{
build(late_[i],rt);
}
print1(rt);
while (!qwq.empty())
{
putchar(qwq.top());
qwq.pop();
}
return 0;
}
void build(int ch,tree *root)
{
if (root->ch==-1||root->ch==ch)//相等或者是新的节点
{
root->ch=ch;//直接赋值不多说
return ;
}
else if (root->ch<ch)//小于建左树
{
if (root->lson==NULL)//如果没开点就开点
{
root->lson=new tree();
clear_(root->lson);
}
build(ch,root->lson);//递归建左子树
}
else //那就只剩下大于咯
{
if (root->rson==NULL)//如果没开点就开点
{
root->rson=new tree();
clear_(root->rson);
}
build(ch,root->rson);//递归建右子树
}
}
inline void clear_(tree *root)
{
root->lson=root->rson=NULL;
root->ch=-1;
}
void print1(tree *root)//先序排列
{
if (root->lson!=NULL)print1(root->lson);
if (root->rson!=NULL)print1(root->rson);
qwq.push(ic[root->ch]);
}
看看这一长串代码,令人生畏......
首先把题目摆上......
题目描述
给出一棵二叉树的中序与后序排列。求出它的先序排列。(约定树结点用不同的大写字母表示,长度\(n≤8\))。
输入输出格式
输入格式:
2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序排列。
输出格式:
11行,表示一棵二叉树的先序。
输入输出样例
输入样例#1: 输出样例#1: BADCBDCAABCD
拿过来一看,不就是模拟吗!
但是我们将原先的中序和后序都离散化成二叉搜索树(闲得慌????),就变得好理解了许多(中规中蒟)
原文作者说:
因为对于二叉搜索树左小右大的原则,其中序遍历即为树中的元素的升序排列。而后序遍历是按先左子右子再根节点的顺序输出。
因此 对于二叉搜索树而言——
如果按照其后序遍历的颠倒后的顺序插入元素,就可以还原整棵树!
原因是在元素x被插入以前,x的父节点已经插入在树中(后序遍历的颠倒后的顺序),因此x一定会插入到原来的树中的位置上。
原来如果我们按照颠倒的后序遍历建一个二叉搜索树,然后将输出的字符串存入stack<char>,然后再倒着输出,就完成先序遍历的操作。
感觉有点迷?不要紧,还有一发。
Q1:为什么要颠倒插入?
A:因为后序遍历就是离散化后的从大到小的排序,所以我们将其反转,就可以得到一个先序遍历。按照先序遍历,可以还原整棵树。
Q2:为什么最后要颠倒输出?
因为我们得到的是先序遍历的离散化数据,所以答案反而是逆序的字母串。
Clear?
题解 P1030 【求先序排列】的更多相关文章
- 洛谷 P1030 求先序排列 Label:None
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...
- 二叉树的遍历 &【NOIP2001普及组】& 洛谷 P1030 求先序排列
题目链接 https://www.luogu.org/problemnew/show/P1030 模板题 先讲一下二叉树的遍历 二叉树的遍历 分类 性质 求法 分为三类: 先序遍历(PreOrder) ...
- P1030 求先序排列 /// 二叉树的遍历
题目大意: 给一棵树的中序排列 后序排列,求这棵树的先序排列 https://www.luogu.org/problemnew/show/P1030 二叉树的四种遍历解说 几种遍历的递归实现 后序排列 ...
- P1030 求先序排列 P1305 新二叉树
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度\le 8≤8). 输入输出格式 输入格式: 22行,均为大写字母组成的字符串,表示一棵二叉树的中序与 ...
- 洛谷P1030求先序排列
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度≤8. 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序排列. 输 ...
- 洛谷:P1087 FBI树 P1030 求先序排列 P1305 新二叉树
至于为啥把这三个题放到一起,大概是因为洛谷的试炼场吧,三道树的水题,首先要理解 先序中序后序遍历方法. fbi树由于数量小,在递归每个区间时,暴力跑一遍区间里的数,看看是否有0和1.至于递归的方法,二 ...
- P1030 求先序排列
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...
- 洛谷 P1030 求先序排列
题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度<=8). 输入输出格式 输入格式: 2行,均为大写字母组成的字符串,表示一棵二叉树的中序与后序 ...
- 洛谷——P1030 求先序排列
https://www.luogu.org/problem/show?pid=1030#sub 题目描述 给出一棵二叉树的中序与后序排列.求出它的先序排列.(约定树结点用不同的大写字母表示,长度< ...
- P1030 求先序排列 (一个非常棒的写法)
理论正确就是真正的正确,误... 就是找嘛,找到每一个对应字符,然后对应的左右子树的区间,然后就可以了. #include <bits/stdc++.h> using namespace ...
随机推荐
- 模板自定义函数 template function
sqlite3中的日期默认是UTC,当日期字段的默认值是CURRENT_TIMESTAMP时,这个日期和北京时间CST少了8小时. 网上建议说数据库里用UTC,读取数据时再转换为当地时间. web页面 ...
- linux系统下php通过php_oci8扩展连接oracle数据库 Nginx
相关版本信息: PHP Version 5.6.30 nginx version: nginx/1.10.3 Linux version 2.6.32-358.el6.x86_64 (mockbuil ...
- 20155238 2016-2017-2 《JAVA程序设计》第八周学习总结
教材学习内容总结 第十四章 NIO NIO使用频道(Channel)来衔接数据节点,处理数据时,NIO可以让你设定缓冲区(Buffer)容量, 在缓冲区对感兴趣的数据区块进行标记,对于这些标记,提供了 ...
- springmvc接收json注意事项
在以前使用SpringMvc框架时,在接受json数据时碰到了一些奇怪的问题.这里记录下来,方便以后查阅. 1. data 里写json对象 , 即该json数据没有被单(双)引号包住 ...
- 由于未能创建 Microsoft Visual C# 2008 编译器,因此未能打开项目 "..."的解决方法
如果遇到这种问题,我们通常只要在 Visual Studio 2017 的命令提示符工具里执行下列命令即可: devenv /resetskippkgs 如果还是不行的话,可以先把 Visual St ...
- JVM技术周报第1期
JVM技术周报 · 第1期 JVM技术每周分享整理了JVM技术交流群每周讨论的内容,由群内成员整理归纳而成.如果你有兴趣入群讨论,请关注「Java技术精选」公众号,通过右下角菜单「入群交流」加我好友, ...
- pt-online-schema-change的实现原理
pt-online-schema-change用于MySQL的在线DDL. 下面结合官方文档和general log来分析其实现原理. 测试表 mysql> show create table ...
- Mvc4_语法基础介绍
@model MvcApplicationTest.Models.User @{ ViewBag.Title = "Index"; } <script type=" ...
- STM32下载Bin文件的几种方式
一.STM32 ST-LINK Utility 1.下载安装软件 官网下载地址:http://www.st.com/zh/development-tools/stsw-link004.html 百度网 ...
- Harbor 学习分享系列1 - centos7.4安装harbor1.5.2
centos7.4安装harbor1.5.2 前言 本系列分享将Harbor有关教程:分享形式会以百度云盘的形式进行分享,主要教程将以markdown格式进行分享:建议使用markdownpad2这款 ...