题目描述
本题为填空题,只需要算出结果后,在代码中使用输出语句将所填结果输出即可。
X 星球的盛大节日为增加气氛,用 30 台机光器一字排开,向太空中打出光柱。
安装调试的时候才发现,不知什么原因,相邻的两台激光器不能同时打开! 国王很想知道,在目前这种 bug 存在的情况下,一共能打出多少种激光效果?
显然,如果只有 3 台机器,一共可以成 5 种样式,即: 全都关上(sorry, 此时无声胜有声,这也算一种);开一台,共 3 种;开两台,只 1 种。
30 台就不好算了,国王只好请你帮忙了。
要求输出一个整数,表示 30 台激光器能形成的样式种数。
运行限制
- 最大运行时间:1s
- 最大运行内存: 128M
//2
//3
//5
//8
//13
//打表找规律
#include<iostream>
using namespace std;
int Fib(int n)
{
if(n == 1)
return 2;
if(n == 2)
return 3;
return Fib(n - 1) + Fib(n - 2);
}
int main()
{
int n = Fib(30);
cout << n << endl;
}
//递归搜索
#include<iostream>
using namespace std;
long long ans = 0;
int sta[33];
void dfs(int x)
{
if(x == 31){
ans++;
return ;
}
dfs(x + 1);//这个灯关的
if(sta[x - 1] == 0)
{
sta[x] = 1; //打开这个灯,向下搜索
dfs(x + 1);
sta[x] = 0;
}
return ;
}
int main()
{
dfs(1);
cout << ans << endl;
return 0;
}