我是靠谱客的博主 刻苦戒指,最近开发中收集的这篇文章主要介绍[atcoder caddi2018]D.Harlequin——博弈论,觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

题目大意:

给定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——博弈论所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(48)

评论列表共有 0 条评论

立即
投稿
返回
顶部