1220: FBI树 [递归]

时间限制: 1 Sec 内存限制: 128 MB

提交: 5 解决: 4 状态

题目描述

我们可以把由“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树,并输出它的后序遍历序列。

输入

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

对于40%的数据,N <= 2;

对于全部的数据,N <= 10。

输出

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

样例输入

  1. 3
  2. 10001011

样例输出

  1. IBFBBBFIBFIIIFF
  1. 因为为了练习二叉树才写的这道题,所以第一次是用建立二叉树的方法A的代码略长,后来发现可以递归自己写了个递归,,,最后看到了别人家的递归!!!下面:
    巧妙地利用了返回值判断零一串!
    #include<cstdio>
  2. #include<cstring>
  3. using namespace std;
  4. const int maxn=(1<<10);
  5. char s[maxn+20];
  6. int write(int l,int r)
  7. {
  8. if(l==r)
  9. {
  10. printf("%c",(s[l]=='0')?'B':'I'); //是零表明是B串,输出B并返回0,1表明是I串输出I并返回1
  11. return s[l]=='1';
  12. }
  13. int sl,sr,k=(l+r)/2;
  14. sl=write(l,k),sr=write(k+1,r);
  15. if(sl+sr==0){printf("B");return 0;} //如果左右两部分递归后返回值相加为零说明这是个零串,是二说明是‘1’串
  16. if(sl+sr==2){printf("I");return 1;}
  17. printf("F"); return 3; //否则就是01串
  18. }
  19.  
  20. int main()
  21. {
  22. while( scanf("%s%s",s,s)!=EOF)
  23. write(0,strlen(s)-1),printf("\n");
  24. return 0;
  25. }
  26.  
  27. 自己写的递归,因为加了判断01的部分略长

#include<iostream>
#include<cstring>
#include<cstdio>
using namespace std;
char s[10005];
void dfs(int x,int y)
{
int t1=0,t2=0;
if(x==y) {printf("%c",(s[x]=='1'?'I':'B'));return;}
else{
int m=(x+y)/2;
dfs(x,m);
dfs(m+1,y);
for(int i=x;i<=y;++i) if(s[i]=='0') ++t1;
else if(s[i]=='1') ++t2;
if(t1&&t2) cout<<'F';
else if(t1&&!t2) cout<<'B';
else cout<<'I';
}
}
int main()
{
int n,m,i,j;
while(scanf("%s%s",s,s)!=EOF) dfs(0,strlen(s)-1),printf("\n");
return 0;
}

  1.  

 

~递归递归(FBI树--蓝桥)的更多相关文章

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

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

  2. 【递归+树】FBI树

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

  3. 蓝桥杯之FBI树问题

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

  4. Java实现 蓝桥杯VIP 算法训练 FBI树

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

  5. C#递归生成HTML树,C#递归生成xml树

    C#递归生成HTML树 public StringBuilder str = new StringBuilder();   //定义一个字符串 private void get_navigation_ ...

  6. 递归遍历JSON树

    递归遍历JSON树 前几天有个人问我,json串的层级无限深,但在json串中的key是已知的,在json串中的value,有些事Object,有些是Array,如何把这些层级无限深的key所对应的v ...

  7. JavaScript通过父节点ID递归生成JSON树

    JavaScript通过父节点ID递归生成JSON树: · 实现思路:通过递归实现(第一次递归的时候查询出所有的父节点,然后通过当前父节点id不断地去查询所有子节点,直到递归完毕返回)   · 代码示 ...

  8. Vijos 1114 FBI树

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

  9. noip普及组2004 FBI树

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

随机推荐

  1. MongoDB— 细说操作

    基本操作 由于是开篇,就大概的说下基本的“增删查改“,我们再开一个cmd,输入mongo命令打开shell,其实这个shell就是mongodb的客户端, 同时也是一个js的编译器,默认连接的是“te ...

  2. ACM题目————中位数

    题目描述 长为L的升序序列S,S[L / 2]为其中位数. 给出两个等长升序序列S1和S2,求两序列合并并排序后的中位数. 输入 多组数据,每组第一行为n,表示两个等长升序序列的长度. 接下来n行为升 ...

  3. this逃逸

    首先,什么是this逃逸? this逃逸是指类构造函数在返回实例之前,线程便持有该对象的引用. 常发生于在构造函数中启动线程或注册监听器. eg: public class ThisEscape { ...

  4. .axf 转化 .bin文件 的方法

    按住shift 右击按键,进入在 X:\Program Files\Keil\MDK510\ARM\ARMCC\bin . 中打开命令cmd.exe ,然后进入一下操作. 编译自己的工程,并将&quo ...

  5. IPMB接口协议总结

    IPMB接口协议总结 IPMB,智能平台管理总线, 是ATCA(Advanced Telecom Computing Architecture)先进的电信计算平台的各FRU背板通讯的两组冗余I2C总线 ...

  6. 【第三十五章】 metrics(3)- codahale-metrics基本使用

    <!-- metrics --> <dependency> <groupId>io.dropwizard.metrics</groupId> <a ...

  7. C#调用系统蜂鸣(需要发出警告时挺好用的 即使没有声卡)

    http://heavenslv.iteye.com/blog/1033870 // 声明 public class BeepUp { /// <param name="iFreque ...

  8. C#学习笔记(五):while循环和for循环

    while循环 while循环和for循环,可以相互替换,范围和效能一样,理解事物的逻辑不一样 while循环用于条件不确定的逻辑 for循环用于计算次数的逻辑 for循环 快捷写法,按两下TAB i ...

  9. vue router菜单 存在点哪个但还是会显示active

    <router-link to="/" exact>Home</router-link> <router-link to="/add&quo ...

  10. Ubuntu 14.04 编写service 服务

    有时我们需要将特定操作封装成服务,通过服务启动停止,例如nginx的启动停止,service nginx start 或者service nginx stop 下面我们将编写一个demo cd /et ...