zoukankan      html  css  js  c++  java
  • HDU 5601 N*M bulbs 找规律

    N*M bulbs

    题目连接:

    http://codeforces.com/contest/510/problem/C

    Description

    NM个灯泡排成一片,也就是排成一个NM的矩形,有些开着,有些关着,为了节约用电,你要关上所有灯,但是你又很懒。

    刚好有个熊孩纸路过,他刚好要从左上角的灯泡走去右下角的灯泡,然后离开。

    但是毕竟熊孩纸,熊孩纸在离开一个灯泡之前,一定会动一下当前开关,也就是开的变关,关的变开。

    想问你可不可能关完所有的灯,同时熊孩纸也可以到达右下角的灯泡,然后离开。

    Input

    第一行T,表示T组数据。

    接下来T组数据:

    每组数据,第一行N,M,后面一个N*M的01矩阵,表示灯泡的初始开关状态,0表示关,1表示开。

    1≤T≤10

    1≤N,M≤1000

    Output

    每组数据,如果可以输出"YES",否则输出"NO"。

    Sample Input

    1

    1 5

    1 0 0 0 0

    Sample Output

    YES

    Hint

    题意

    题解:

    我们发现操作数跟n+m-1n+m−1同奇偶,那是不是当11的个数跟n+m-1n+m−1同奇偶是就是YES呢?

    答案是肯定的,我们这样看:首先将棋盘黑白染色,就是若(i,j)(i,j)格子,若(i+j)(i+j)是奇数,那么就是黑格子,否则就是白格子。

    我们发现我们可以通过一种操作使得从一个格子走到斜方向的任意一个格子。

    这个操作很简单,我们假设一个2*22∗2的棋盘:

    1 2

    3 4

    我们这样走:1->2->1->2->41−>2−>1−>2−>4, 11就直接走到44了,而且不产生任何操作。

    也就是同色格子可以互相到达。

    然后我们发现如果要操作一个开关,那么最后所在格子颜色一定会改变。

    同上面这个例子:

    1 2

    3 4

    假设我们要操作22这个格子。

    1->2->1->31−>2−>1−>3

    我们成功操作了22这个格子,但是从白格子转到黑格子了。

    也就是说

    假设格子(n,m)(n,m)下面有个格子(n+1,m)(n+1,m)是最后终点,然而每次操作一个格子需要改变一次颜色。

    也就是我们从(1,1)(1,1)改变了若干次颜色后,最后颜色一定要和(n+1,m)(n+1,m)相同。

    也就是说11的个数要和(n+1+m)(n+1+m)同奇偶。

    也就是说11的个数要和(n+m-1)(n+m−1)同奇偶。

    否则无解。

    代码

    #include<bits/stdc++.h>
    using namespace std;
    
    int main()
    {
        int t;scanf("%d",&t);
        while(t--)
        {
            int n,m,x,sum=0;
            scanf("%d%d",&n,&m);
            for(int i=1;i<=n;i++)
            {
                for(int j=1;j<=m;j++)
                {
                    scanf("%d",&x);
                    if(x==1)
                        sum++;
                }
            }
            if((n+m-1)%2==sum%2)
                puts("YES");
            else puts("NO");
        }
    }
  • 相关阅读:
    upstream sent unsupported FastCGI protocol version: 72 while reading response header from upstream
    当代免疫学小史-第一章(根据讲谈社Blue Backs系列2009年第一版第三次印刷版本翻译)
    微信小程序自定义tabbar解决方案(可用于解决tabbar跳转至分包页面问题)
    celery的使用
    分布式之数据库和缓存双写一致性方案解析
    opencv实战-全景图像拼接
    matplotlib+seaborn样式管理-学习整理
    matplotlib绘制3D图形
    matplotlib+seaborn图形绘制-学习整理
    opencv实战-文档扫描
  • 原文地址:https://www.cnblogs.com/qscqesze/p/5079167.html
Copyright © 2011-2022 走看看