博客
关于我
FBI树
阅读量:326 次
发布时间:2019-03-04

本文共 1449 字,大约阅读时间需要 4 分钟。

FBI树 ⁡ \operatorname{FBI树} FBI

题目链接:

题目

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

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

  1. T T T 的根结点为 R R R ,其类型与串 S S S 的类型相同;
  2. 若串 S S S 的长度大于 1 1 1 ,将串 S S S 从中间分开,分为等长的左右子串 S 1 S_1 S1 S 2 S_2 S2 ;由左子串 S 1 S_1 S1 构造 R R R 的左子树 T 1 T_1 T1 ,由右子串 S 2 S_2 S2 构造 R R R 的右子树 T 2 T_2 T2

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

输入

第一行是一个整数 N ( 0 ≤ N ≤ 10 ) N(0 \le N \le 10) N(0N10)

第二行是一个长度为 2 N 2^N 2N 的“ 01 01 01 ”串。

输出

一个字符串,即 FBI 树的后序遍历序列。

样例输入

310001011

样例输出

IBFBBBFIBFIIIFF

数据范围

对于 40 % 40\% 40% 的数据, N ≤ 2 N \le 2 N2

对于全部的数据, N ≤ 10 N \le 10 N10

思路

这道题就是直接模拟。

就直接模拟啊,一个字符串先看是全 0 0 0 ,全 1 1 1 ,还是都有。接着如果这个字符串不知一个字符就要分开两半再处理。

因为要输出后序遍历,就先分开两半处理(如果要),在输出这个字符对应的字母。

代码

#include
using namespace std;int n;char a[1051];void work(int l, int r) { int check = a[l] - '0';//看字符串是怎样的 for (int i = l + 1; i <= r; i++) if ((a[i] - '0') != check) { check = -1; break; } if (l < r) { //不是一个字符,还要分 int mid = (l + r) >> 1; work(l, mid); work(mid + 1, r); } if (check == -1) printf("F");//输出 else if (check == 0) printf("B"); else printf("I");}int main() { scanf("%d", &n);//读入 for (int i = 1; i <= (1 << n); i++) { a[i] = getchar(); while (a[i] != '0' && a[i] != '1') a[i] = getchar(); } work(1, 1 << n); return 0;}

转载地址:http://peph.baihongyu.com/

你可能感兴趣的文章
Nginx配置文件nginx.conf中文详解(总结)
查看>>
nginx配置详解、端口重定向和504
查看>>
Nginx配置负载均衡到后台网关集群
查看>>
Nginx配置限流,技能拉满!
查看>>
Nginx面试三连问:Nginx如何工作?负载均衡策略有哪些?如何限流?
查看>>
Nginx:NginxConfig可视化配置工具安装
查看>>
ngModelController
查看>>
ngrok | 内网穿透,支持 HTTPS、国内访问、静态域名
查看>>
NHibernate学习[1]
查看>>
NHibernate异常:No persister for的解决办法
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_日期类型_以及null数据同步处理补充---大数据之Nifi工作笔记0057
查看>>
NIFI1.21.0_Mysql到Mysql增量CDC同步中_补充_更新时如果目标表中不存在记录就改为插入数据_Postgresql_Hbase也适用---大数据之Nifi工作笔记0059
查看>>
NIFI1.21.0_NIFI和hadoop蹦了_200G集群磁盘又满了_Jps看不到进程了_Unable to write in /tmp. Aborting----大数据之Nifi工作笔记0052
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表多表增量同步_增删改数据分发及删除数据实时同步_通过分页解决变更记录过大问题_02----大数据之Nifi工作笔记0054
查看>>
NIFI1.21.0通过Postgresql11的CDC逻辑复制槽实现_指定表或全表增量同步_实现指定整库同步_或指定数据表同步配置_04---大数据之Nifi工作笔记0056
查看>>
NIFI1.23.2_最新版_性能优化通用_技巧积累_使用NIFI表达式过滤表_随时更新---大数据之Nifi工作笔记0063
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_根据binlog实现数据实时delete同步_实际操作04---大数据之Nifi工作笔记0043
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI从MySql中离线读取数据再导入到MySql中_03_来吧用NIFI实现_数据分页获取功能---大数据之Nifi工作笔记0038
查看>>