news 2026/4/16 18:04:17

FBI树(fbi)(信息学奥赛一本通- P1365)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
FBI树(fbi)(信息学奥赛一本通- P1365)

【题目描述】

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

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

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

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

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

【输入】

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

【输出】

一行,这一行只包含一个字符串,即FBI树的后序遍历序列。

【输入样例】

3 10001011

【输出样例】

IBFBBBFIBFIIIFF

【提示】

对于40%的数据,N≤2;

对于100%的数据,N≤10。

//是一颗满二叉树,我们用顺序存储 #include <iostream> #include <algorithm> #include <cmath> using namespace std; string a; char tre[5000]; void postorder(int root){ if(tre[root*2]) postorder(root*2); if(tre[root*2+1]) postorder(root*2+1); cout<<tre[root]; } int main(){ int n; cin>>n; cin>>a; //先给最后一层赋值 int cnt=0; //把顺序存储最后一行的叶子节点先存进去 for(int i=pow(2,n);i<pow(2,n+1);i++){ if(a[cnt]=='1') tre[i]='I'; else if(a[cnt]=='0') tre[i]='B'; cnt++; } //建树 倒着建 n+1就是总层数 for(int i=n;i>=1;i--){//该树总共会有n层 for(int j=pow(2,i);j<pow(2,i+1);j=j+2){//每层有这么多个节点 if(tre[j]==tre[j+1]) tre[j/2]=tre[j]; else tre[j/2]='F'; } } //后序遍历 postorder(1); return 0; }
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/16 15:30:31

Rust语言开发者的新工具:Seed-Coder-8B-Base代码支持上线

Rust语言开发者的新工具&#xff1a;Seed-Coder-8B-Base代码支持上线 在现代系统编程领域&#xff0c;Rust以其内存安全与高性能的双重优势&#xff0c;正逐步成为操作系统、嵌入式系统乃至WebAssembly场景下的首选语言。然而&#xff0c;这种强大能力的背后&#xff0c;是陡峭…

作者头像 李华
网站建设 2026/4/16 15:29:56

Nginx负载均衡部署多个ACE-Step实例:应对大规模访问需求

Nginx负载均衡部署多个ACE-Step实例&#xff1a;应对大规模访问需求 在短视频、游戏和影视内容爆发式增长的今天&#xff0c;对背景音乐的自动化生成需求正以前所未有的速度攀升。一个热门短视频可能需要数十种风格各异的配乐进行A/B测试&#xff0c;而一部动画电影则涉及成百上…

作者头像 李华
网站建设 2026/4/16 4:36:17

DS4Windows终极配置指南:释放PS4手柄在PC上的全部潜能

问题定位&#xff1a;为什么你的PS4手柄在PC上表现不佳&#xff1f; 【免费下载链接】DS4Windows Like those other ds4tools, but sexier 项目地址: https://gitcode.com/gh_mirrors/ds/DS4Windows 许多玩家发现将PlayStation手柄连接到PC时&#xff0c;会遇到兼容性差…

作者头像 李华
网站建设 2026/4/11 18:57:31

ParsecVDD虚拟显示器完整指南:从入门到精通

ParsecVDD虚拟显示器完整指南&#xff1a;从入门到精通 【免费下载链接】parsec-vdd ✨ Virtual super display, upto 4K 2160p240hz &#x1f60e; 项目地址: https://gitcode.com/gh_mirrors/pa/parsec-vdd ParsecVDD是一款功能强大的虚拟显示器工具&#xff0c;能够为…

作者头像 李华