蓝桥杯刷题023——机器人塔(DFS)
创始人
2024-05-25 23:26:45
0

2016国赛

题目描述

X 星球的机器人表演拉拉队有两种服装,A 和 B。

他们这次表演的是搭机器人塔。

类似:

         A

       B B

     A B A

    A A B B

  B B B A B

A B A B B A

队内的组塔规则是:

A 只能站在 AA 或 BB 的肩上。

B 只能站在 AB 或 BA 的肩上。

你的任务是帮助拉拉队计算一下,在给定 A 与 B 的人数时,可以组成多少种花样的塔。

输入描述

输入一行两个整数 M,N(0

输出描述

要求输出一个整数,表示可以产生的花样种数。

输入输出样例

输入

1 2

输出

3

题目大意

给出A,B两类机器人,让它们按—定规则堆成三角形塔,问可堆成的方案数
规则:

A只能放在AA,BB上B只能放在AB,BA上

思考:如何确定每一个方案   

  • 问题转换成:确定第一层(最下一层)的A,B分布情况即可

因为第一行确定了,第二次也随之确定(根据组塔规则),以此类推,所有的机器人的位置都是确定的。

        机器人的层数由机器人数量决定,1+2+3+...+n=\frac{n(1+n)}{2}\leq 100,n最大可取到13,所以最多13层。一个位置可以放A和B两种,所以第一层最多能放2^n=2^{13}\approx 10^4种,这个计算量不高。

A,B两个状态的表示

二进制法:
用0表示A,用1表示B
从最后一层向上递推的过程:

递推的结果符合异或运算的性质

解题思路:二进制枚举+异或运算递推

1、根据输入的A,B机器人数推算层数n:  N+M\rightarrow n
2、二进制法求底层AB的所有情况
3、对于每个底层,利用异或运算(^)不断向上递推,递推过程中根据二进制数0,1统计A,B机器人剩余未使用的个数
4、如果A,B剩余未使用的个数出现负数,或者到达最顶层时A、B机器人个数不全为0,那么这个方案无效
5、统计所有有效的方案数,即为结果

代码:

d = {}                      # 存机器人数和层数
base = 0
for i in range(1, 20):base += i               # 机器人数d[base] = i
M, N = map(int, input().split())
level = d[M + N]            # 根据机器人数算出有多少层def dfs(cur, clv, m, n):  # cur:当前情况,clv:当前层数(最底层的机器人个数),m:剩余A的人数,n:剩余B的人数if m < 0 or n < 0:    # 排除出现负数的情况return Falseif clv == 0:          # 层数为0return m == n == 0cb = bin(cur)[2:].count('1')  # 转为二进制:0bxxxx(字符串),统计1的个数count('1')ca = clv - cb        # 不直接统计0的个数,因为例如001010最前面的两个0没办法计入m -= ca; n -= cbup = (cur ^ (cur >> 1)) & ((1 << (clv - 1)) - 1)  # 计算出上一层的情况return dfs(up, clv - 1, m, n)        # 搜索上一层(层数-1)res = 0
for case in range(1 << level):    # 遍历2^n种情况if dfs(case, level, M, N):res += 1
print(res)

注:下面对代码up = (cur ^ (cur >> 1)) & ((1 << (clv - 1)) - 1) 进行解释

例如:cur为22(二进制位10110),clv为6

1、cur >> 1:将cur右移一位,右移一位为1011;

     1 << (clv - 1):1向左移动clv-1位,为01111

2、 (cur ^ (cur >> 1)):求上一层的情况,但最左边多出来一位

 

3、& ((1 << (clv - 1)) - 1):和一个二进制位为01111相与(&)就能去掉最左边的一位。注意“-”的优先级大于“>>”,所以需要加一个括号让<<先算。

相关内容

热门资讯

读什么什么有感的英文 读什么什么有感的英文英语读后感标题 “读XXX有感”用英语说是 “Reading after XX...
秦岚个人资料身高体重 秦岚个人资料身高体重身高:165公分 体重:46公斤秦岚 生日:七月十七日 星座:巨蟹座 出生地:沈...
双鱼和天秤会纠缠一辈子,既相配... 双鱼和天秤会纠缠一辈子,既相配又相克,为什么?双鱼座的人和天秤座的人都是比较细心的,而且特别敏感,有...
独自一人在外怎样和别人相处? 独自一人在外怎样和别人相处?我觉得独自一个人在外面一定要好好的照顾自己,应该找一份工作,找一个住的地...
朱自清散文集有哪些写的好,值得... 朱自清散文集有哪些写的好,值得背诵的?《背影》、《 春》、《 荷塘月色》、《 匆匆》都是不错的佳...
大家最讨厌的电视剧的哪一个主角... 大家最讨厌的电视剧的哪一个主角?我觉得最讨厌的电视剧主角是容嬷嬷。都挺好,里面的苏大强就是越看越别扭...
69DT伤害怎么才能上1300... 69DT伤害怎么才能上1300 !我加点是4L1M!现在60了!伤害才800!我没大号,想买梦幻币买...
孩子上课不认真听讲 孩子上课不认真听讲我的孩子七周半,已经上二年级了,但是上课不认真听讲总是搞小动作,说了很多次也不听,...
《红脸儿》的主要内容 《红脸儿》的主要内容  红脸儿主要内容:   小说以散淡而富有诗意的语言回顾了“我”与3个小伙伴之间...
异地恋的成功例子 异地恋的成功例子 情侣异地恋8年终成正果 两人存下186张火车票见证爱情一对河南的情侣在大学恋爱时便...
小狗吃了死耗子怎么办 小狗吃了死耗子怎么办你好,没事的,放心吧,你的小狗是宠物狗还是土狗,若是宠物狗的话可能会给它造成身体...
请问有没有死亡万花筒广播剧资源... 请问有没有死亡万花筒广播剧资源?死亡万花筒,我有呀!死亡万花筒广播剧,地·址:9525.video(...
徐缺有哪些女人 徐缺有哪些女人徐缺是小说《最强反套路系统》中的角色,他有许多女性关系,其中包括:1. 林小红:徐缺的...
假如我是四大名著中的人物作文9... 假如我是四大名著中的人物作文900假如你是的林黛玉的话那你就会好好读书,不至于连900个字都写不出了...
西游记81难? 西游记81难?西游记的81难是师徒四人取经回来在河中落水经书被淹了的事
魔兽世界风暴王子问题! 魔兽世界风暴王子问题!现在3.05这版本 王子第4阶段的屏障 是不是可以被MS驱散? 屏障驱散后是...
如何评价张杰的少年中国说 如何评价张杰的少年中国说我觉得非常棒,张杰的家庭条件不好。从小就非常努力。刻苦学习音乐,经过拼搏奋斗...
智取生辰纲中杨志是怎样的人?他... 智取生辰纲中杨志是怎样的人?他失败的原因是什么?简短些志有智慧,但是他忽略了一个重要的因素:团队的合...
有一本书,名字忘记了.好象是美... 有一本书,名字忘记了.好象是美国人写的.梭罗《瓦尔登湖》 如果你用的是新教材,应该是这篇吧是 海明威...
四岁孩子看什么书 四岁孩子看什么书可以看一些带有简单数字的书、色彩鲜艳的图画、动物图画等,培养他的数字感和色彩感,尽量...