1747: 硬币翻转
时间限制: 1 Sec 内存限制: 128 MB提交: 41 解决: 14
[ 提交][ 状态][ 讨论版]
题目描述
Brother Hardware和Sister Software经常在一起玩硬币翻转的游戏,游戏是在一个N*M(N行,M列)的棋盘上进行,左上角是(1,1),右下角为(N,M)。初始状态棋盘上每个位置都有个硬币,不是朝上就是朝下。
游戏的规则如下:
1. 两人轮流进行操作,不能进行操作的人输,当棋盘上所有硬币都朝下时游戏结束;
2. 每次操作操作者选定一个位置(x,y),该位置的硬币必须朝上,如果找不到这样的位置,操作者为败者。根据左上角(x,y)和右下角(N,M)确定一个矩形,然后翻转这个矩形区域内的所有硬币,即把朝上的变成朝下的,把朝下的变成朝上的;
游戏每次都是Brother Hardware先行,两个人都足够聪明,假如给你最初棋盘的分布情况,谁最终谁能赢?
输入
第一行输入一个正整数T,接下来有T组数据( T≤100 )。
每组数据的首行输入N和M(N,M如上所述),接下来输入N行,每行有M个正整数,每个正整数不是0就是1,0表示硬币向下,1表示硬币向上。(1≤N,M≤50 )
输出
每组数据输出一行,如果Brother Hardware能赢,输出 YES,否则输出 NO。
刚开始看到这题吧,显然就是一个博弈问题,因为每次翻转都已经固定了一个右下角。所以每次翻转,右下角的硬币必然改变状态。。。看到了所以我猜测肯定与这个硬币的状态有关系,就试着画了俩图简单模拟了一下。发现还真的是。。。(⊙o⊙)…
并且样例的输入输出给的都是特殊情况,显然就是掩耳盗铃,所以没错。真相就是这样。哈哈哈哈。右下角为1就是YES
然后直接AC咯。。。
#include<stdio.h>
int main()
{
int T,N,M,x;
scanf("%d",&T); ///心血来潮贴个c的代码咯,对了,下面的int i忘改了,c好像不支持这样做吧,好像、、、
while(T--)
{
scanf("%d%d",&N,&M);
for(int i=0; i<N; i++)
for(int j=0; j<M; j++)
scanf("%d",&x);
if(x) puts("YES");
else puts("NO");
}
return 0;
}