1592 问题 F: 蓝桥杯算法训练VIP-FBI树

时间限制: 1s 内存限制: 128MB 提交: 479 解决: 239
题目描述
我们可以把由“0”和“1”组成的字符串分为三类:全“0”串称为B串,全“1”串称为I串,既含“0”又含“1”的串则称为F串。
FBI树是一种二叉树,它的结点类型也包括F结点,B结点和I结点三种。由一个长度为2N的“01”串S可以构造出一棵FBI树T,递归的构造方法如下:
1)T的根结点为R,其类型与串S的类型相同;
2)若串S的长度大于1,将串S从中间分开,分为等长的左右子串S1和S2;由左子串S1构造R的左子树T1,由右子串S2构造R的右子树T2。

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

FBI树

输入

第一行是一个整数N(0  < =  N  < =  10),第二行是一个长度为2N的“01”串。 

数据规模和约定,对于全部的数据,N  < =  10。

注:
[1]  二叉树:二叉树是结点的有限集合,这个集合或为空集,或由一个根结点和两棵不相交的二叉树组成。这两棵不相交的二叉树分别称为这个根结点的左子树和右子树。
[2]  后序遍历:后序遍历是深度优先遍历二叉树的一种方法,它的递归定义是:先后序遍历左子树,再后序遍历右子树,最后访问根。

输出
包括一行,这一行只包含一个字符串,即FBI树的后序遍历序列。
样例输入
3 
10001011 
样例输出
IBFBBBFIBFIIIFF
提示
零基础同学可以先学习视频课程,包含C/C++、Python、百练、蓝桥杯辅导、算法数据结构等课程,提供视频讲解以及配套习题,还有老师答疑,点击这里了解课程详情

比赛公告

历年真题,不限组别,均可参加

欢迎贡献题解,博客发布后可以私信管理员Q2045302297领奖品~



想举办自己的比赛吗? 校内赛或者模拟赛,都可以使用Dotcpp的自主比赛创建自己的比赛!

无需预约、完全免费!

图文教程:https://blog.dotcpp.com/a/9993