湖南工业大学创新实验室2015年新生赛(一)1006(重开)
Too simple
Time Limit : 3000/1000ms (Java/Other) Memory Limit : 65535/32768K (Java/Other)
Total Submission(s) : 33 Accepted Submission(s) : 17
Font: Times New Roman | Verdana | Georgia
Font Size: ← →
Problem Description
Alice和Bob又在玩游戏惹。有一堆石子,石子总数为n。她们轮流取石子,每个人每次可以取走两个或者一个石子。另外如果Alice先手,那么取走最后一颗石子的输。如果Bob先手,那么取走最后一颗石子的获胜。假设两人都采取最佳策略,你的任务是根据石子数目和谁先手判断谁会赢。
难度:★
(hint:简单找规律即可。如果当前状态能够推出一个先手必败状态,那么当前状态为先手必胜状态。如果当前状态不能推出任一个先手必败状态,那么当前状态为先手必败状态)
难度:★
(hint:简单找规律即可。如果当前状态能够推出一个先手必败状态,那么当前状态为先手必胜状态。如果当前状态不能推出任一个先手必败状态,那么当前状态为先手必败状态)
Input
输入一个正整数t,接下来t组数据,每组包含n(1<=n<2^31)和Alice或Bob,代表先手的是谁
Output
对每组数据输出一行,输出胜者
Sample Input
3 1 Alice 2 Alice 3 Bob
Sample Output
Bob Alice Alice
Author
Source
light oj
很简单的博弈,当需要取走最后一颗石子的获胜时,只要n%(m+1)!=0,则先取者一定获胜,当取走最后一颗石子的输时,有(n-1)%(m+1)==0则后手胜利
#include<stdio.h>
//#include<bits/stdc++.h>
#include<string.h>
#include<iostream>
#include<math.h>
#include<sstream>
#include<set>
#include<queue>
#include<vector>
#include<algorithm>
#include<limits.h>
#define inf 0x3fffffff
#define lson l,m,rt<<1
#define rson m+1,r,rt<<1|1
#define LL long long
using namespace std;
int main()
{
int n,m,Case;
string s;
cin>>Case;
while(Case--)
{
cin>>n>>s;
if(s=="Bob")
{
if(n%(3)!=0)
{
puts("Bob");
}
else
{
puts("Alice");
}
}
else
{
if((n-1)%3==0)
{
puts("Bob");
}
else
{
puts("Alice");
}
}
}
}

浙公网安备 33010602011771号