目录:

·题目描述

·知识拓展

·题目分析

·思路分析

·代码实现

·总结


·题目描述:

(洛谷P1087 FBI树)

  我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串。

  FBI树是一种二叉树,它的结点类型也包括F结点,B结点和I结点三种。由一个长度为2^N的“01”串S可以构造出一棵FBI树T,递归的构造方法如下:

  1) T的根结点为R,其类型与串S的类型相同;

  2) 若串S的长度大于1,将串S从中间分开,分为等长的左右子串S1S2;由左子串S1​构造R的左子树T1​,由右子串S2​构造R的右子树T2​。

  现在给定一个长度为2^N的“01”串,请用上述构造方法构造出一棵FBI树,并输出它的后序遍历序列

·知识拓展:

  关于遍历的顺序:

  (1)先序遍历:

    

    如图,这是一个二叉树,A为根结点。这张图如果用先序遍历表示的话,应为ABDEGHJCFIKL。总的来说,先序遍历的遍历方式为先根后左再右,简记为:根左右

  (2)中序遍历:

    

    如图,还是这个二叉树,但是这张图如果用中序遍历表示的话,应为DBGEJHAFIKLC。不难看出,后序遍历的遍历方式为先左后根再右,简记为:左根右

  (3)后序遍历:

    

    又是这张图,还是这个二叉树,用后序遍历表示这张图的话,应为DGJHEBKLIFCA。与上面的两种遍历方式相比较,可知,后序遍历的遍历方式为先左后右再根,简记为:左右根

·题目分析:

  刚拿到这道题时,我没有仔细读题,只是将样例中的字符串写成了树,然后又按照后序遍历将这个字符串重新排列,将排列之后的字符串两个一组判断是F、B或I,但是这明显是错的。

  本题的意思是将字符串写成树后,对每一个结点先进行判断F、B或I,然后按照后序遍历输出,没有对字符串长度的限制,不能两个一组进行判断

·思路分析:

  对于这道题,我们可以采用边建树边输出的方法,结合深搜(其实就是一个大大的暴力),就可以得到这个题目的大致思路:

  我们可以设一个dfs(l,r)函数,这个函数表示从l到r的字符串建树(并且输出F、B、I)

  如果r-l>1,就将这个函数变为dfs(l,mid)和dfs(mid+1,r),其中mid为l和r的中点,就是(l+r)/2

  如果r-l=1,这个函数就递归到了尽头,则需要按照后序遍历的方式将F、B、I输出

·代码实现:

  好了,talk is cheap,show me the code

 #include<iostream>
#include<string>
using namespace std;
int n;
string s;
void dfs(int l,int r){
if(l==r){
if(s[l]=='')cout<<'B';
if(s[l]=='')cout<<'I';
return ;
}
int mid=(l+r)/;
dfs(l,mid);
dfs(mid+,r);//后序遍历
bool B=true;//全是0
bool I=true;//全是1
for(int i=l;i<=r;i++){
if(s[i]=='')B=false;//有1
if(s[i]=='')I=false;//有0
}
if(B)cout<<'B';
else if(I)cout<<'I';
else cout<<'F';
}
int main(){
cin>>n>>s;//用cin会好一点TwT
dfs(,(<<n)-);//0~2^n-1
}

  

·总结:

  这道题属于典型的“挂羊头卖狗肉”问题,题目名称和题目中的各个方面都是跟树相关,但是这个题目的解决方法却与树并没有太大的关系(虽然也用到了树的知识)。虽然自己图论学的不够好,但也不能因为题目中的暗示放弃了解题的机会啊!

搜索练习题——FBI树的更多相关文章

  1. Vijos 1114 FBI树

    描述 我们可以把由"0"和"1"组成的字符串分为三类:全"0"串称为B串,全"1"串称为I串,既含"0&quo ...

  2. 【递归】Vijos P1114 FBI树(NOIP2004普及组第三题)

    题目链接: https://vijos.org/p/1114 题目大意: 把01串一分为二,左半边描述当前节点左子树,右半边描述右子树,子树全为1则为I节点,全为0则为B节点,混合则为F节点,直到当前 ...

  3. 创建FBI树

    需求:数串由2^n个'0' '1'数串组成,对于一个数串,有01混合出现,则视为F,全0数串为B,全1数串为I. 将给定数串进行切割,如10010011可以用二叉树表示为 F(10010011) / ...

  4. 蓝桥杯之FBI树问题

    问题描述 我们可以把由"0"和"1"组成的字符串分为三类:全"0"串称为B串,全"1"串称为I串,既含"0&q ...

  5. noip普及组2004 FBI树

    FBI树 描述 我们可以把由"0"和"1"组成的字符串分为三类:全"0"串称为B串,全"1"串称为I串,既含" ...

  6. Vijos P1114 FBI树【DFS模拟,二叉树入门】

    描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串. FBI树是一种二叉树1,它的结点类型也包括F结点,B结点和I结点三种 ...

  7. [题解]ybt1365:FBI树(fbi)

    ybt1365:FBI树(fbi) [题目描述] 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串. FBI树是一种二叉树,它 ...

  8. FBI树-数据结构(二叉树)

    问题 B: [2004_p4]FBI树-数据结构 时间限制: 1 Sec  内存限制: 125 MB提交: 57  解决: 46 题目描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称 ...

  9. C语言 · FBI树

    算法训练 FBI树   时间限制:1.0s   内存限制:256.0MB        锦囊1 二叉树. 问题描述 我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I ...

随机推荐

  1. 新手的Linux zcat命令示例

    Zcat是一个命令行实用程序,用于查看压缩文件的内容.它将压缩文件扩展为标准输出,允许您查看内容. 分类:Linux命令操作系统 2018-08-13 00:00:00 通常,使用gzip压缩的文件可 ...

  2. java数据结构复习02

    1.递归问题 1.1汉诺塔问题(递归) 问题描述三个柱子,起初有若干个按大小关系顺序安放的盘子,需要全部移动到另外一个柱子上.移动规则:在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘.移动 ...

  3. boost多线程编译出错

    添加 -lpthread CPLUS_INCLUDE_PATH=$CPLUS_INCLUDE_PATH:/tools/boost/includeexport CPLUS_INCLUDE_PATH LI ...

  4. Django 创建 hello world

    前言 用Django 创建 hello 哈哈,对这个还是有点意思的 创建文件 在你的目录下 比如我是 F:\python\django 的输入下面的代码: django-admin startproj ...

  5. react-native window下创建Hello(解决创建一路的坑)

    今天真的颇为激动,1年没有玩RN,竟然被最新的RN版本0.55.4创建Hello折腾了半天,想当年刚玩RN创建环境用了3天, 想想现在也是不容易啊半天就搞定了,目测以后创建的话也就1-2个小时就搞定了 ...

  6. 初识Python,利用turtle画图

    目录 我的第三篇博客 一.初识Python 1.变量 2.注释 3.turtle库 我的第三篇博客 一.初识Python 1.变量 变量就是可变的的量,用来描述某个事物的属性.本质作用就是描述和接收变 ...

  7. rsync快速部署记录

    rsync快速部署记录 安装rsync和使用环境:客户端:10.192.30.59 fudao_db_cluster_002 (将本地文件备份到服务端)服务端:10.192.30.60 fudao_d ...

  8. 【NOIP2016提高A组五校联考1】挖金矿

    题目 分析 我们二分答案 设\(sum_{i,j}\)表示的i列前个数的和, 假设当前出的二分答案为x,第i列挖了\(h_j\)层,则 \[\dfrac{\sum_{i=1}^{n}sum_{i,h_ ...

  9. 【leetcode】638. Shopping Offers

    题目如下: In LeetCode Store, there are some kinds of items to sell. Each item has a price. However, ther ...

  10. SQL结果统计 GROUP BY

    在结果几种,使用GROUP BY进行相同项求和的时候SELECT的字段要与GROUP BY后面的一一对应. select M.TIME,M.PRODUCTMODEL,M.PROCESS_PRODUCT ...