题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
X 星球的盛大节日为增加气氛,用 30 台机光器一字排开,向太空中打出光柱。
安装调试的时候才发现,不知什么原因,相邻的两台激光器不能同时打开! 国王很想知道,在目前这种 bug存在的情况下,一共能打出多少种激光效果?
显然,如果只有 3 台机器,一共可以成 5种样式,即: 全都关上(sorry, 此时无声胜有声,这也算一种);开一台,共 3 种;开两台,只 1 种。
30 台就不好算了,国王只好请你帮忙了。
要求输出一个整数,表示 30 台激光器能形成的样式种数。
运行限制
最大运行时间:1s
最大运行内存: 128M
```cpp
#include <iostream>
using namespace std;
int sum = 0;
void dp(int array, int rightOneIndex)
{
if (rightOneIndex + 2 >= 30) //边界
{
return;
}
for (int i = rightOneIndex + 2; i < 30; i++)
{
array |= (1 << i); //将array的第i位置1
sum++;
dp(array, i);
array &= ~(1 << i); //回溯 将array的第i位置0
}
}
int main()
{
//int a=pow(2,30)-1;
//string nums = { "111111111111111111111111111111" };
//cout << bitset<30>(a) << endl;
//cout << nums << endl;
//cout << nums.size() << endl;
int array = 0;
for (int i = 0; i < 30; i++)
{
array |= (1 << i); //将array的第i位置1
sum++;
dp(array, i);
array &= ~(1 << i); //回溯 将array的第i位置0
}
cout << sum + 1; //加上一个全空的情况
}