有一堆个数为n(n>=2)的石子,游戏双方轮流取石子,规则如下:
1)先手不能在第一次把所有的石子取完,至少取1颗;
2)之后每次可以取的石子数至少为1,至多为对手刚取的石子数的2倍。
约定取走最后一个石子的人为赢家,求必败态。
结论:当n为Fibonacci数的时候,必败。
f[i]:1,2,3,5,8,13,21,34,55,89……
证明就略了吧,可以看其他的博客,我就简单记下结论
#include<bits/stdc++.h>
using namespace std;
int fib[50];
int main()
{
fib[0]=1;fib[1]=2;
for(int i=2; i< 45;i++)
fib[i]=fib[i-1]+fib[i-2];
int n;
while(cin>>n&&n){
int i=0;
for(i=0;i<45;i++)
if(fib[i]==n)
break;
if(i<45)
printf("Second win\n");
else printf("First win\n");
}
return 0;
}