题目描述

有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格。每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗)。我们可以通过若干操作使魔板从一个状态改变为另一个状态。操作的方式有两种:
  (1)任选一行,改变该行中所有灯泡的状态,即亮的变暗、暗的变亮;
  (2)任选两列,交换其位置。
  当然并不是任意的两种状态都可以通过若干操作来实现互相转化的。
  你的任务就是根据给定两个魔板状态,判断两个状态能否互相转化。

输入格式

文件中包含多组数据。第一行一个整数k,表示有k组数据。
  每组数据的第一行两个整数n和m。(0<n,m≤100)
  以下的n行描述第一个魔板。每行有m个数字(0或1),中间用空格分隔。若第x行的第y个数字为0,则表示魔板的第x行y列的灯泡为“亮”;否则为“暗”。
  然后的n行描述第二个魔板。数据格式同上。
  任意两组数据间没有空行。

输出格式

共k行,依次描述每一组数据的结果。
  若两个魔板可以相互转化,则输出YES,否则输出NO。(注意:请使用大写字母)

输入输出样例

输入
  2
  3 4
  0 1 0 1
  1 0 0 1
  0 0 0 0
  0 1 0 1
  1 1 0 0
  0 0 0 0
  2 2
  0 0
  0 1
  1 1
  1 1

输出

YES

NO

分析

一直以为是个结论题没想到居然是个暴力枚举的。。。。。。

先来手玩一下就可以发现(并不,所以每行最多只有可能变换一次,不然就换回来了。

所以每一行就会有两种情况,变和不变

然后yyq暴力2^n枚举每行的变化情况加剪枝大力出奇迹过了这个题

其实除了2^n枚举之外,还有一种枚举方法

对于每一列来说,列的变换不会改变数字

先假设能成功

那么如果我们知道第1个矩阵中的某一列经过变换后成为第2个矩阵的某一列,

那我们就可以通过比较两个列哪些数字不同,推出哪些行是变换了的

所以我们直接去枚举第1个矩阵中的第一列经过变换后成为第2个矩阵的第i列

然后推出哪些行是变换了,进而n^3判断剩下的列是否可行。

如果全都不行则无解

复杂度是O(kn^4),开开O2应该可以过

我不信你100张牌能秒我???(雾

代码

#include<cstdio>
#include<cstring>
int T,n,m,rev[],vis[],nw[][],nx[][];
bool check(int x)
{
memset(vis,,sizeof vis);vis[x]=;
for(int j=;j<=m;j++)
{
int flag=;
for(int k=;k<=m;k++)if(!vis[k])
{
flag=;
for(int i=;i<=n;i++)flag&=(nw[i][j]==(rev[i]^nx[i][k]));
if(flag){vis[k]=;break;}
}
if(!flag)return ;
}
return ;
}
int main()
{
for(scanf("%d",&T);T;T--)
{
scanf("%d%d",&n,&m);int flag=;
for(int i=;i<=n;i++)for(int j=;j<=m;j++)scanf("%d",&nw[i][j]);
for(int i=;i<=n;i++)for(int j=;j<=m;j++)scanf("%d",&nx[i][j]);
for(int i=;i<=m&&!flag;i++)
{
memset(rev,,sizeof rev);
for(int j=;j<=n;j++)rev[j]=(nw[j][]!=nx[j][i]);
flag=check(i);
}
if(flag)puts("YES");else puts("NO");
}
}

【洛谷】P1275 魔板(暴力&思维)的更多相关文章

  1. 洛谷P1275 魔板

    P1275 魔板 题目描述 有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格.每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗).我们可以通过若干操作使魔板从一个状态改变为另一个状 ...

  2. 洛谷 P1275 魔板

    P1275 魔板 题目描述 有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格.每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗).我们可以通过若干操作使魔板从一个状态改变为另一个状 ...

  3. [洛谷P2730] 魔板 Magic Squares

    洛谷题目链接:魔板 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都 ...

  4. 洛谷P2730 魔板 [广搜,字符串,STL]

    题目传送门 魔板 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都有 ...

  5. 洛谷 P2730 魔板 Magic Squares 解题报告

    P2730 魔板 Magic Squares 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 ...

  6. 洛谷 P2730 魔板 Magic Squares

    P2730 魔板 Magic Squares 题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 ...

  7. 洛谷 - P2730 - 魔板 Magic Squares - bfs

    写状态转移弄了很久,老了,不记得自己的数组是怎么标号的了. #include <bits/stdc++.h> using namespace std; #define ll long lo ...

  8. 【题解】魔板—洛谷P1275。

    话说好久没更博了. 最近学了好多知识懒的加进来了. 有幸认识一位大佬. 让我有了继续更博的兴趣. 但这是一个旧的题解. 我在某谷上早就发过的. 拿过来直接用就当回归了吧. 其实这道题有一个特别关键的思 ...

  9. P1275 魔板

    题目描述 有这样一种魔板:它是一个长方形的面板,被划分成n行m列的n*m个方格.每个方格内有一个小灯泡,灯泡的状态有两种(亮或暗).我们可以通过若干操作使魔板从一个状态改变为另一个状态.操作的方式有两 ...

随机推荐

  1. 【洛谷 P4137】 Rmq Problem / mex(主席树)

    题目链接 容易发现,可能答案只有\(0\).每个数,每个数\(+1\) 于是把这\(2n+1\)个数建立一个权值线段树,可持久化一下,每个节点记录这个子树中最后加入数加入的时间的最小值\(latest ...

  2. CSS的基本知识

    与HTML相同,CSS也是一种标识语言,即可以在任何文本编辑器中打开和修改 CSS的基本结构 选择器(Selector) 选择器告诉浏览器该样式将会作用于哪些对象,这些对象可以是某个标签.某个对象.网 ...

  3. js --桥接模式

    定义: 将抽象部分与它的实现部分分离,使他们都可以独立的变化. 也就是说,桥接模式里面有两个角色: - 扩充抽象类 - 具体实现类 在写桥接模式之前,想在写一下关于抽象的理解.我觉得抽象这个概念过于抽 ...

  4. JQ分页的使用

    <script src="../js/pageMe.js"></script> <script src="../js/comjq.js&qu ...

  5. 笔谈OpenGL ES(二)

    昨晚回家也看了OpenGL ES 2.0 iOS教程的第一篇,对于其中涉及的一些基本知识罗列下,虽然自己做iOS开发一年多了,但是对于一些细节没有注意,真正的把自己当成“应用”工程师了 ,不仅要会用, ...

  6. p1.BTC-密码学的原理

    所谓加密货币是不加密的,区块链上所有的交易内容(包括:账户的地址,转账的地址)都是公开的. Bitcoin中主要用到密码学的中的两个功能:Hash和签名. 一 Hash Cryptographic h ...

  7. git 常见的命令和错误

  8. SQL EXPLAIN优化详解

    使用EXPLAIN关键字可以模拟优化器执行SQL查询语句,从而知道MySQL是 如何处理你的SQL语句的.分析你的查询语句或是表结构的性能瓶颈.使用方式:Explain+SQL语句执行计划包含的信息: ...

  9. test20190814 NOIP2019 模拟题

    二叉树 [问题描述] 从前有一棵二叉树,我们用如下方式来表示这棵二叉树. 如果一个节点没有儿子,我们用"0"来表示他. 如果一个节点有一个儿子,我们对它的表示以"1&qu ...

  10. TVS瞬态抑制二极管选型指南

    一.TVS二极管工作原理 TVS(Transient Voltage Suppressors)二极管,即瞬态电压抑制器,又称雪崩击穿二极管,是采用半导体工艺制成的单个PN结或多个PN结集成的器件.TV ...