6980. 【2021.02.03冬令营模拟】你的世界(world) Another Solution
Problem Description
Input
从文件
world.in
中读入数据。
Output
输出到文件
world.out
中。输出共 T 行,第 i 行表示第 i 组测试数据的答案,如果可行则输出 Yes,否则输出 No。
Sample Input Copy
样例输入1:
1
2 3
000
000
111
001 样例输入2:
1
3 4
0000
0101
0001
1011
0001
1100 样例输入3:
1
4 5
11000
01010
00011
10110
00011
11001
11010
10001
Sample Output Copy
样例输出1:
Yes 样例输出2:
Yes 样例输出3:
No
Data Constraint
首先,\(A\gets A\oplus B\),我们的问题就变成了怎么操作使得一个空矩阵变成新的矩阵 \(A\)。
先考虑只能操作行和列,该怎么做。
如果这张图是合法的,我们发现对于任意的 \(2\times2\) 子矩阵 \(\begin{bmatrix}
a_{0,0} & a_{0,1} \\
a_{1,0} & a_{1,1}
\end{bmatrix}\),有 \(a_{0,0}\oplus a_{0,1}\oplus a_{1,0}\oplus a_{1,1}=0\)。
我们来证明一下,因为对于操作行和列,一定会操作 \(2\times2\) 子矩阵中的任意两个,那么异或结果不变。
所以,我们定义 \(a_{0,0},a_{0,1},a_{1,0},a_{1,1}\) 这类异或结果不变的为固定元素,其余的为不固定元素。
\(2\times2\) 子矩阵中有固定元素,也就是这个子矩阵被固定了,所以它合法。
存不存在更小的子矩阵呢?比如说 \(1\times1\) 子矩阵。
答案是不存在的,因为对于一个 \(1\times1\) 子矩阵 \(\begin{bmatrix}
a_{0,0}
\end{bmatrix}\),我们可以随意修改这个点,所以不存在固定元素,不合法。
考虑加入对角线操作。
如果还是刚刚的 \(2\times2\) 矩阵,我们发现由于对角线操作的加入可以出现形如 \(\begin{bmatrix}
0 & 1 \\
1 & 1
\end{bmatrix}\),\(\begin{bmatrix}
0 & 0 \\
0 & 1
\end{bmatrix}\) 等等等等的矩阵,子矩阵中没有一个元素是固定元素,这个子矩阵是不固定的!
所以考虑更大的子矩阵。
考虑一个 \(4\times4\) 子矩阵,我们发现对于任意的 \(4\times4\) 子矩阵 \(\begin{bmatrix}
a_{0,0} & \textcolor{red}{a_{0,1}} & \textcolor{red}{a_{0,2}} & a_{0,3} \\
\textcolor{red}{a_{1,0}} & a_{1,1} & a_{1,2} & \textcolor{red}{a_{1,3}} \\
\textcolor{red}{a_{2,0}} & a_{2,1} & a_{2,2} & \textcolor{red}{a_{2,3}} \\
a_{3,0} & \textcolor{red}{a_{3,1}} & \textcolor{red}{a_{3,2}} & a_{3,3} \\
\end{bmatrix}\),有 \(a_{0,1}\oplus a_{0,2}\oplus a_{1,0}\oplus a_{1,3}\oplus a_{2,0}\oplus a_{2,3}\oplus a_{3,1}\oplus a_{3,2}=0\)。(为了方便我将这些固定元素标红)
证明显然:
- 对于 \(a_{0,0},a_{0,3},a_{3,0},a_{3,3}\),可以进行一个对角线操作,所以这些元素是可以随便调整的,是不固定元素;
- 对于 \(a_{0,1},a_{0,2},a_{1,0},a_{1,3},a_{2,0},a_{2,3},a_{3,1},a_{3,2}\),这些元素无法抵消,只能进行对角线同时操作两个固定元素,所以异或结果不会变化;
- 对于 \(a_{1,1},a_{1,2},a_{2,2},a_{2,2}\),这些元素可以通过乱搞抵消,具体自己乱搞。
所以这个子矩阵是固定的。
我们继续发现,不存在比 \(4\times4\) 还小的子矩阵。
所以这道题就很简单了,枚举矩阵 \(A\) 的子矩阵左上角 \((i,j)\),只需要所有的子矩阵均满足满足 \(a_{i,j+1}\oplus a_{i,j+2}\oplus a_{i+1,j}\oplus a_{i+1,j+3}\oplus a_{i+2,j}\oplus a_{i+2,j+3}\oplus a_{i+3,1}\oplus a_{j+3,2}=0\),则这张图有解。
时间复杂度 \(O(nm)\)。
然后这道题就可以开始加强了,比如加入各种新印章,都可以用这种方法轻松解决。
#include <cstdio>
#include <chrono>
#include <random>
using namespace std;
using namespace chrono;
#define ll long long
#define N 1010
ll t, n, m;
char a[N][N], b[N][N];
int main() {
freopen("world.in", "r", stdin);
freopen("world.out", "w", stdout);
scanf("%lld", &t);
while(t--) {
scanf("%lld %lld", &n, &m);
for(ll i = 1; i <= n; i++) {
scanf("%s", a[i]+1);
}
for(ll i = 1; i <= n; i++) {
scanf("%s", b[i]+1);
for(ll j = 1; j <= m; j++) {
if(a[i][j] == b[i][j]) a[i][j] = 0;
else a[i][j] = 1;
}
}
bool flag = 1;
for(ll i = 1; i <= n - 3; i++) {
for(ll j = 1; j <= m - 3; j++) {
if(a[i][j+1] ^ a[i][j+2] ^ a[i+1][j] ^ a[i+1][j+3] ^ a[i+2][j] ^ a[i+2][j+3] ^ a[i+3][j+1] ^ a[i+3][j+2]) {
printf("No\n");
flag = 0;
break;
}
}
if(!flag) break;
}
if(flag) printf("Yes\n");
}
}
6980. 【2021.02.03冬令营模拟】你的世界(world) Another Solution的更多相关文章
- 02.02.03第3章 餐饮项目案例(Power BI商业智能分析)
02.02.03第3章 餐饮项目案例 02.02.03.01餐饮数据理解与读入 00:06:12 02.02.03.02餐饮数据处理 00:29:57 处理生成的表为: 02.02.03.03餐饮数据 ...
- [2018冬令营模拟测试赛(二十一)]Problem A: Decalcomania
[2018冬令营模拟测试赛(二十一)]Problem A: Decalcomania 试题描述 输入 见"试题描述" 输出 见"试题描述" 输入示例 见&quo ...
- 【2020.02.01NOIP普及模拟4】怪兽
[2020.02.01NOIP普及模拟4]怪兽 文章目录 [2020.02.01NOIP普及模拟4]怪兽 题目描述 输入 输出 输入输出样例 数据范围限制 提示 解析 code 题目描述 PYWBKT ...
- 2021.11.03 P6175 无向图的最小环问题
2021.11.03 P6175 无向图的最小环问题 P6175 无向图的最小环问题 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 题意: 给定一张无向图,求图中一个至少包含 33 ...
- 2021.11.03 P2886 [USACO07NOV]Cow Relays G(矩阵+floyed)
2021.11.03 P2886 [USACO07NOV]Cow Relays G(矩阵+floyed) [P2886 USACO07NOV]Cow Relays G - 洛谷 | 计算机科学教育新生 ...
- 2021.05.03 T3 数字
2021.05.03 T3 数字 问题描述 一个数字被称为好数字当他满足下列条件: 1. 它有**2*n**个数位,n是正整数(允许有前导0) 2. 构成它的每个数字都在给定的数字集合S中. 3. 它 ...
- 2021.08.03 BZOJ 疯狂的馒头(并查集)
2021.08.03 BZOJ 疯狂的馒头(并查集) 疯狂的馒头 - 题目 - 黑暗爆炸OJ (darkbzoj.tk) 重点: 1.并查集的神奇运用 2.离线化 题意: 给一个长为n的序列,进行m次 ...
- 2021.08.03 P1197 星球大战(并查集)
2021.08.03 P1197 星球大战(并查集) [P1197 JSOI2008]星球大战 - 洛谷 | 计算机科学教育新生态 (luogu.com.cn) 重点: 1.可以离线处理.把在线变为离 ...
- 2021.04.03【NOIP提高B组】模拟 总结
T1 题目大意:求最小的 \(n\in[0,lim]\) 使得区间 \([L,R]\) 在线段树建树 \(build(0,n)\) 的区间内 考场时想到了正解,结果推式子退错了... 其实就是从下往上 ...
- 纪中集训2020.02.03【NOIP提高组】模拟B 组总结反思——登机(board),游戏(game),分组(group)
T1 JZOJ5535. 登机(board) 比赛时 一在题目列表里看到题目标题,就热血沸腾了,不知道为什么,老师居然放了一道之前做过的题目.我清楚地记得这题是DP,于是很快码了出来.讲一讲我的思路, ...
随机推荐
- vite + vue3 打包后 本地直接运行 type="module" crossorigin 替换为defer - 多个vue文件就不好使了
vite + vue3 打包后 本地直接运行 type="module" crossorigin 替换为defer 需求: 想打包后,双击运行,不启动服务 修改 vite.conf ...
- STM32 SPI DMA 源码解析及总结
一 前言 最近在调试stm32的SPI时候i,遇到了一个非常诡异的问题.中间花费了不少时间才把问题搞定.这中间暴露的问题值得反思.借此机会,还是梳理一下stm32的SPI的代码做一个总结吧. 二 初始 ...
- Oracle注入—报错注入
Oracle注入-报错注入 1.Oracle报错注入知识扫盲 一.Oracle报错注入知识扫盲 报错注入 报错注入就是,输入的一些能让数据库出错的语句,数据库会把这个错误回显给我们 OK,,什么语句能 ...
- 后端基础SQL—数据库简介与SQL语法
数据库简介与SQL语法 1.数据库简介 2.数据库结构 3.SQL语句 4.SQL基本语法 5.MySQL基础查询语句 6.高级查询与子查询 7.渗透测试常用函数 8.判断闭合类型 一.数据库简介 数 ...
- gRPC入门学习之旅(二)
gRPC入门学习之旅(一) gRPC是一个高性能.通用的开源远程过程调用(RPC)框架,基于底层HTTP/2协议标准和协议层Protobuf序列化协议开发,支持众多的开发语言,由Google开源. g ...
- PyQt5 Ubuntu 16.04/14.04 环境配置
PS:要转载请注明出处,本人版权所有. PS: 这个只是基于<我自己>的理解, 如果和你的原则及想法相冲突,请谅解,勿喷. 前置说明 本文作为本人csdn blog的主站的备份.(Bl ...
- springboot如何优雅的获取前端参数
写在前面 对于初学者来说,困难的不是理论知识,而是如何在程序中具体实现. 现在的项目基本上都是前后端分离的项目,如何打通前后端,接收前端传过来的参数呢? 废话不多说,这篇文章就来说一说接收前端参数的具 ...
- 说说如何在Vue项目中应用TypeScript?
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 一.前言 与link类似 在VUE项目中应用typescript,我们需要引入一个库vue-property-decorator, 其是基 ...
- 记录--uniapp登录流程详解uni.login
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 uni.login(OBJECT)登录 H5平台登陆注意事项: 微信内嵌浏览器运行H5版时,可通过js sdk实现微信登陆,需要引入一个单 ...
- 记录--什么时候会阻塞HTML文档渲染过程?
这里给大家分享我在网上总结出来的一些知识,希望对大家有所帮助 HTML页面加载过程会发生什么?因为浏览器网络拉取资源是多线程的,但是dom树的操作都是在一个线程中的,所以网页资源的解析.js加载.do ...