概述
题目大意:
给定n堆石子,每一次可以从不同的堆中取1个石子或者不取,求最后的谁获胜。
思路:
一种状态E全部都是偶数,另外一种状态O即存在奇数。
不难发现最后的状态为E。
如果拿到了E不论怎么操作都会变成O,如果拿到了O总有办法变成E,即先手必胜的状态为O,先手必败的状态为E。
#include<bits/stdc++.h>
#define REP(i,a,b) for(int i=a,i##_end_=b;i<=i##_end_;++i)
#define DREP(i,a,b) for(int i=a,i##_end_=b;i>=i##_end_;--i)
#define debug(x) cout<<#x<<"="<<x<<endl
#define fi first
#define se second
#define mk make_pair
#define pb push_back
typedef long long ll;
using namespace std;
void File(){
freopen("d.in","r",stdin);
freopen("d.out","w",stdout);
}
template<typename T>void read(T &_){
_=0; T f=1; char c=getchar();
for(;!isdigit(c);c=getchar())if(c=='-')f=-1;
for(;isdigit(c);c=getchar())_=(_<<1)+(_<<3)+(c^'0');
_*=f;
}
const int maxn=1e5+10;
int n,a[maxn];
int main(){
File();
read(n);
REP(i,1,n)read(a[i]);
REP(i,1,n)if(a[i]%2)return puts("first"),0;
puts("second");
return 0;
}
最后
以上就是刻苦戒指为你收集整理的[atcoder caddi2018]D.Harlequin——博弈论的全部内容,希望文章能够帮你解决[atcoder caddi2018]D.Harlequin——博弈论所遇到的程序开发问题。
如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。
本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
发表评论 取消回复