HNUST 1747: 硬币翻转(简单博弈)

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;
}


  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值