题目链接:求先序排列

这道题讲白了,就是数的构造,然后遍历。

思路大致是这样:

我们先通过后序遍历,找到当前区间的根,然后在中序遍历中找到根对应的下标,然后就可以分出左右子树,建立当前根与左右子树根的关系,然后分为两段,重复该操作即可。

先序遍历也没有什么难的,先输出根,然后判断是否有左右子树,有的话递归输出,没有就算。

下面上代码:

#include<bits/stdc++.h>
using namespace std;
struct point{ //1
int p; //2
int lc;
int rc;
}poi[26]; //3
void build(int* mid,int* back,int ml,int mr,int bl,int br){
if(mr-ml<1){ //4
return;
}
int root=back[br]; //5
int index;
for(int i=ml;i<=mr;i++){
if(mid[i]==root){
index=i; //6
break;
}
}
if(index-1>=ml){ //7
poi[root].lc=back[index-1-ml+bl];
poi[back[index-1-ml+bl]].p=root;
build(mid,back,ml,index-1,bl,index-1-ml+bl);
}
if(mr>=index+1){
poi[root].rc=back[br-1];
poi[back[br-1]].p=root;
build(mid,back,index+1,mr,index-ml+bl,br-1);
} }
void treeprint(int root){
printf("%c",root+'A'); //8
if(poi[root].lc!=-1){ //9
treeprint(poi[root].lc);
}
if(poi[root].rc!=-1){
treeprint(poi[root].rc);
}
}
int main(){
char mid[10],back[10];
int midn[10],backn[10];
char c;
scanf("%s",mid);
scanf("%c",&c);
scanf("%s",back);
for(int i=0;i<26;i++){ //10
poi[i].p=-1;
poi[i].lc=-1;
poi[i].rc=-1;
}
int i;
for(i=0;mid[i]!='\0';i++){ //11
midn[i]=mid[i]-'A';
}
for(i=0;back[i]!='\0';i++){
backn[i]=back[i]-'A';
}
int root=backn[i-1];
build(midn,backn,0,i-1,0,i-1);
treeprint(root);
return 0;
}

讲11点(怪多的哈):

1处:写一个节点结构体。

2处:这个记录父亲没什么用,放在这里仅仅是为了保持节点数据的完整性。

3处:题目没有明确说只用前八个字母,所以还是小心点好,防止被坑。

4处:如果区间长度小于等于1,也就不可能再有子树,那么返回。

5处:找到根。

6处:找到根在中序遍历中的坐标。

7处:判断中序遍历中,根的左右边是否有字符,如果有说明有子树。

8处:打印当前根。

9处:判断是否有子节点。

10处:结构体数据初始化,用于判断左右子树是否为空。

11处:转化成数字便于处理,输出时别忘了转化回去。

求先序排列(NOIP2001&NOIP水题测试(2017082301))的更多相关文章

  1. NOIP水题测试(2017082301)

    你们从题目也能看出来今天的题是很水的. 前几期答案还没出,效率有点低,谅解,谅解. 今天的答案应该会出的很快. 下面给题目: 时间限制:3小时 题目一:旅行家的预算 题目二:进制转换 题目三:乘积最大 ...

  2. 失踪的7(P1590&NOIP水题测试(2017082301))

    题目链接:失踪的7 水题,不解释. #include<bits/stdc++.h> using namespace std; int main(){ int t; scanf(" ...

  3. 子数整数(P1151&NOIP水题测试(2017082301))

    题目链接:子数整数 水题,不解释,自己看代码: #include<bits/stdc++.h> using namespace std; int main(){ int k; scanf( ...

  4. 进制转换(NOIP2000&NOIP水题测试(2017082301))

    题目链接:进制转换 这题得明白其中的数学方法,明白后就不难了. 那么我们应该怎么计算呢? 其实也很简单. 我们依然采取辗转相除法. 但是,对于负的余数,我们需要进行一些处理. 我们怎么处理呢? 很简单 ...

  5. 乘积最大(NOIP2000&NOIP水题测试(2017082301))

    题目链接:乘积最大 这道题显然是道区间dp. 难度不是很大. 思路也很清晰. 我们设计一个三维状态. ans[l][r][k] 这里表示在闭区间[l,r]上操作k次的最大值. 操作就是加乘号. 转移也 ...

  6. NOIP水题测试(2017082401)

    哈,水题测试又来了! 上次的水题简单吧! 答案是以单题形式发布的(旅行家的预算随后发布). 下面来看今天的题,还是水题. 时间限制:5小时 题目一:看上去就很水 题目二:比上面一题还水 题目三:数的划 ...

  7. NOIP水题测试(2017082501)

    日常水题测试又来了! 以后答案都以单题形式公布. 下面看今天的水题: 时间限制:5小时 题目一:无法形容的水 题目二:比上一题还水 题目三:一元三次方程求解 题目四:单词接龙 题目五:统计单词个数 题 ...

  8. 旅行家的预算(NOIP1999&水题测试2017082301)

    题目链接:旅行家的预算 这题还可以,不算太水. 这题贪心即可. 我们采取如下动作: 如果在装满油的情况下能到达的范围内,没有加油站,则无解. 如果在装满油的情况下能到达的范围内,油价最低的加油站的油价 ...

  9. NC16692 [NOIP2001]求先序排列

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

随机推荐

  1. IDEA中配置JUnit单元测试

    参考安装教程:https://www.jianshu.com/p/c37753b6dbd6 如果想用junit4的话,需要在pom.xml中配置. 需要安装JUnitGenerator V2.0插件, ...

  2. 调css时候,设置margin-left没有效果

    调css时候,如果设置margin-left没有效果,可能是span不是块元素.设置display:block;即可.

  3. java多线程与并发笔记

    0.多线程,主要用来提高程序效率,处理耗时的操作. 多个线程写在同一个类里调用,并不是说写在前面的线程就会先运行.各个线程会进行争抢,能抢到系统资源的才会先运行. 因此,同一个程序,多个线程运行,可能 ...

  4. css3 vw、vh属性详解,以及与%、rem的区别介绍

    最近的项目需求,内嵌电视端显示页面,所以使用到了css3的属性:vw \ vh,遇到一些问题,记录下来 vw.vh是什么? 字面上可以简单理解为,vw (view width),vh(view hei ...

  5. shell中参数的传递

    1.命令行参数 向shell脚本传递数据的最基本方式是使用命令行参数. (1) 读取参数 读取输入的参数的变量为位置参数,位置参数通过标准数字表示, 其中$0为程序名称,$1为第一个参数,$2为第二个 ...

  6. Selenium 定位元素原理,基本API,显示等待,隐式等待,重试机制等等

    Selenium  如何定位动态元素: 测试的时候会遇到元素每次变动的情况,例如: <div id="btn-attention_2030295">...</di ...

  7. http://www.bugku.com:Bugku——PHP伪协议+魔幻函数+序列化的综合应用(http://120.24.86.145:8006/test1/)

      这一道题目,幸好俺有基础知识护体,不然还真干不掉.     首先,登录看题目,取消隐藏代码的注释.可知可输入三个参数txt.file和password并进行逻辑判断:应该让txt==‘welcom ...

  8. python------栈和队列的实现

    一.神马是栈 古有粮仓,即为栈.粮仓的特点就是最后放进去的谷粒,放在最上面.打仗行军,取粮是怎么取最快?肯定是最先取最上面的!栈这一种常用到的数据结构就是这种特点:后进先出(Last In First ...

  9. css重要知识点

    1.float:left;表示靠左显示.它是相对于距离最近的且以relative作为position的父元素而言的. 2.块级元素和行内元素 块级元素:占据了一个矩形框的元素,display属性的值为 ...

  10. 自定义进度条渐变色View

    package com.jianke.stepCounter.Activity; import android.annotation.SuppressLint; import android.cont ...