【问题描述】
x星球的盛大节日为增加气氛,用30台机光器一字排开,向太空中打出光柱。
安装调试的时候才发现,不知什么原因,相邻的两台激光器不能同时打开!
国王很想知道,在目前这种bug存在的情况下,一共能打出多少种激光效果?
显然,如果只有3台机器,一共可以成5种样式,即:
1、全都关上(sorry, 此时无声胜有声,这也算一种)
2、开一台,共3种
3、开两台,只1种
但是30台就不好算了,国王只好请你帮忙了。
【答案提交】
要求提交一个整数,表示30台激光器能形成的样式种数。
注意,只提交一个整数,不要填写任何多余的内容。
答案:2178309
#include <iostream>
using namespace std;
int main()
{ //f[i][0]表示第个灯为0的方案数
int f[30][2];
f[0][0] = 1; //i==0表示第一个灯
f[0][1] = 1;
for (int i = 1; i <= 29; i ++)
{
f[i][0] = f[i - 1][0] + f[i - 1][1];
// 这一位是0,那么前面可以是0,也可以是1
f[i][1] = f[i - 1][0];
// 这一位是1,那么前面只能是0
}
cout << f[29][0] + f[29][1] << endl;
return 0;
}
//
#include <iostream>
using namespace std;
int main()
{ //f[i][0]表示第个灯为0的方案数
int f[35][2];
f[0][0] = 1; //i==1表示第一个灯
f[0][1] = 0; //没有灯开不了
for (int i = 1; i <= 30; i ++)
{
f[i][0] = f[i - 1][0] + f[i - 1][1];
// 这一位是0,那么前面可以是0,也可以是1
f[i][1] = f[i - 1][0];
// 这一位是1,那么前面只能是0
}
cout << f[30][0] + f[30][1] << endl;
return 0;
}
//位运算暴力
#include <iostream>
using namespace std;
int judge(int x,int k){
return x>>k&1; //判断X的K位是不是1
}
int main()
{
int cnt=0;
for (int i = 0; i < 1<<30; i ++) //数的范围
{
bool flag = true;
for (int j = 1; j < 30; j ++){
if(judge(i,j)&&judge(i,j-1)){
flag=false;
break;
}
}
cnt+=flag;
}
cout<<cnt<<endl;
return 0;
}
#include <iostream>
using namespace std;
int ans;
const int N = 30;
bool st[N];
void dfs(int u)
{
if(u == 31)
{
ans ++;
return;
}
// 每一次都有两种选择
dfs(u + 1); // 1、关闭,对 u 不进行操作
if(!st[u - 1]) // 2、打开
{
st[u] = true;
dfs(u + 1);
st[u] = false;
}
}
int main()
{
dfs(1);
cout << ans << endl;
return 0;
}