luogu2594 [ZJOI2009]染色游戏
做法其他题解已经说得很清楚了,但似乎没有对于本题 SG 函数正确性的证明,我来口胡一下(
证明:
猜想:
\]
我们要用到一个结论: 局面的 SG 值等于局面中所有反面朝上的硬币单独存在时的 SG 值的异或和 。然而这个结论我不太会证()。我们暂且使用它而不证明。
首先当 \(i=1\lor j=1\) 成立时,本题相当于一维放硬币问题,其 SG 函数等同于一维的 \(lowbit(i)\)。因为 \(i\) 或 \(j\) 中至少有一个是 1,于是我们只需要将横纵坐标相加再 \(-1\) 即可消去为 1 的那一维。
对于其他情况我们使用数学归纳法:
首先对于 \(\operatorname{SG}(2,2)\) ,有以下几种选择方案(下图中 \(0/1\) 代表反转后分别是正面/反面朝上):
\(\begin{matrix} 0&0\\0&0 \end{matrix} ,\operatorname{SG}=0\)
\(\begin{matrix} 0&1\\0&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(1,2)=2\)
\(\begin{matrix} 0&0\\1&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(2,1)=2\)
\(\begin{matrix} 0&1\\1&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(1,2)\space\operatorname{xor}\space \operatorname{SG}(2,1)=0\)
\(\begin{matrix} 1&1\\0&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(1,1)\space\operatorname{xor}\space \operatorname{SG}(1,2)=3\)
\(\begin{matrix} 1&0\\1&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(1,1)\space\operatorname{xor}\space \operatorname{SG}(2,1)=3\)
\(\begin{matrix} 1&1\\1&0 \end{matrix} ,\operatorname{SG}=\operatorname{SG}(1,1)\space\operatorname{xor}\space SG(1,2)\space\operatorname{xor}\space \operatorname{SG}(2,1)=1\)
\(\therefore \operatorname{SG}(2,2)=\operatorname{mex}\{0,2,2,0,3,3,1\}=4\),满足猜想。
还有一种特殊情况就是 \(i=2\land j>2\) 或 \(i>2\land j=2\),不难发现它们是等价的,因此这里我们只以 \(i=2\land j>2\) 为例。此时有 \(\operatorname{SG}(i,j-1)=2^{i+j-3},\operatorname{SG}(i-1,j)=\operatorname{lowbit}(j)\)。由 SG 函数定义有对于左上角为 \((1,1)\),右下角为 \((i,j-1)\) 的不包含右下角的矩形,在其中选择满足题目要求的连通块所得 SG 函数值域取遍 \([0,2^{i+j-3}-1]\)。因此在选择 \((i,j-1)\) 一点与上述矩形范围内取连通块可以取遍 \(2^{i+j-3}\space\operatorname{xor}\space[0,2^{i+j-3}-1]\) 即 \([2^{i+j-3},2^{i+j-2}-1]\) 范围内的值;可以证明在 \(j\ge3\) 时有 \(\operatorname{SG}(i-1,j)=\operatorname{lowbit}(j)\le 2^{i+j-4}\) (在 \(j=3\) 时有 \(\operatorname{lowbit}(3)=1\le 2^{i+j-4}\) ,而在 \(j>3\) 时有 \(\operatorname{lowbit}(j)\le j \le 2^{j-2}=2^{i+j-4}\)),因此在选择 \((i-1,j)\) 一点与上述矩形范围内取连通块可以取遍 \(\operatorname{lowbit}(j)\space\operatorname{xor}\space[0,2^{i+j-3}-1]\) 也即 \([0,2^{i+j-3}-1]\) 范围内的值(因为 \(\operatorname{lowbit}(j)\) 一位上为 1 的数异或后该位会变成 0,为 0 的数该位会变为 1,值域仍取遍)。做一下 mex 可得 \(\operatorname{SG}(i,j)=2^{i+j-2}\),符合猜想。
对于 \(i>2\land j>2\) 的 \((i,j)\),由数学归纳法有 \(\operatorname{SG}(i,j-1)=\operatorname{SG}(i-1,j)=2^{i+j-3}\),由 SG 函数定义有对于左上角为 \((1,1)\),右下角为 \((i,j-1)\) 的不包含右下角的矩形,在其中选择满足题目要求的连通块所得 SG 函数值域取遍 \([0,2^{i+j-3}-1]\)。因此除选择点 \((i,j)\)外,在 \((i,j-1),(i-1,j)\) 两点与上述矩形范围内取连通块可以取遍 \([0,2^{i+j-3}-1]\) 范围内的值,在 \((i,j-1)\) 一点与上述矩形范围内取连通块可以取遍 \(2^{i+j-3}\space\operatorname{xor}\space[0,2^{i+j-3}-1]\) 即 \([2^{i+j-3},2^{i+j-2}-1]\) 范围内的值,做一下 mex 可得 \(\operatorname{SG}(i,j)=2^{i+j-2}\),符合猜想。
证毕。
顺便挂一下代码:
#include <bits/stdc++.h>
using namespace std;
int T , n , m , sg[110][110] , init() , f[220] , flag;
string s;
inline void init()
{
for(int i = 1 ; i <= 100 ; i++ ) sg[i][1] = sg[1][i] = log2(i & (-i));
for(int i = 2 ; i <= 100 ; i++ )
for(int j = 2 ; j <= 100 ; j++ ) sg[i][j] = i + j - 2;
return ;
}
int main()
{
init();
scanf("%d" , &T);
while(T--)
{
memset(f , 0 , sizeof(f)); flag = 0;
scanf("%d%d" , &n , &m);
for(int i = 1 ; i <= n ; i++ )
{
cin >> s;
for(int j = 1 ; j <= m ; j++ )
{
if(s[j - 1] == 'T') f[sg[i][j]] ^= 1;
}
}
for(int i = 0 ; i <= 200 ; i++ )
{
if(f[i])
{
flag = 1;
break;
}
}
if(flag) printf("-_-\n");
else printf("=_=\n");
}
return 0;
}
/*
1
3 4
TTHH
THTH
TTHH
*/
luogu2594 [ZJOI2009]染色游戏的更多相关文章
- [luogu2594 ZJOI2009]染色游戏(博弈论)
传送门 Solution 对于硬币问题,结论是:当前局面的SG值等于所有背面朝上的单个硬币SG值的异或和 对于求单个背面朝上的硬币SG值...打表找规律吧 Code //By Menteur_Hxy ...
- 【BZOJ1434】[ZJOI2009]染色游戏(博弈论)
[BZOJ1434][ZJOI2009]染色游戏(博弈论) 题面 BZOJ 洛谷 题解 翻硬币的游戏我似乎原来在博客里面提到过,对于这类问题,当前局面的\(SG\)函数就是所有反面朝上的硬币单一存在时 ...
- [ZJOI2009]染色游戏
Description 一共n × m 个硬币,摆成n × m 的长方形.dongdong 和xixi 玩一个游戏, 每次可以选择一个连通块,并把其中的硬币全部翻转,但是需要满足存在一个 硬币属于这个 ...
- BZOJ1434:[ZJOI2009]染色游戏(博弈论)
Description 一共n×m个硬币,摆成n×m的长方形.dongdong和xixi玩一个游戏,每次可以选择一个连通块,并把其中的硬币全部翻转,但是需要满足存在一个硬币属于这个连通块并且所有其他硬 ...
- bzoj1434 [ZJOI2009]染色游戏
Description 一共n × m 个硬币,摆成n × m 的长方形.dongdong 和xixi 玩一个游戏, 每次可以选择一个连通块,并把其中的硬币全部翻转,但是需要满足存在一个 硬币属于这个 ...
- BZOJ 1434: [ZJOI2009]染色游戏
一开始想这不$SG$裸题...然后发现100组数据...然后发现连通块是任意的求$SG$貌似要暴力枚举.... 然后想了一下1维,手动打表,每次就是队当前所有异或后缀和求$mex$,好像就是$lowb ...
- BZOJ 1411&&Vijos 1544 : [ZJOI2009]硬币游戏【递推,快速幂】
1411: [ZJOI2009]硬币游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 897 Solved: 394[Submit][Status ...
- bzoj1411: [ZJOI2009]硬币游戏
1411: [ZJOI2009]硬币游戏 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 965 Solved: 420[Submit][Status ...
- 题解 [SDOI2009]E&D/染色游戏/Moving Pebbles
E&D 染色游戏 Moving Pebbles E&D 题目大意 给出 \(2n\) 堆石子,\(2i-1\) 和 \(2i\) 为一组.每次可以选择一组删掉其中一堆,然后从同一组另外 ...
随机推荐
- Jmeter - 把提取的响应结果设置成全局变量
1. 用正则表达式从响应结果中提取需要的字符 2.添加BeanShell 后置处理程序,${__setProperty(setcookies,${cookies},)} 用函数定义其为全局变量 3.调 ...
- TSR交通标志检测与识别
TSR交通标志检测与识别 说明: 传统图像处理算法的TSR集成在在ARM+DSP上运行,深度学习开发的TSR集成到FPGA上运行. 输入输出接口 Input: (1)图像视频分辨率(整型int) (2 ...
- YOLOV4知识点分析(一)
YOLOV4知识点分析(一) 简 介 yolov4论文:YOLOv4: Optimal Speed and Accuracy of Object Detection arxiv:https://arx ...
- Technology Document Guide of TensorRT
Technology Document Guide of TensorRT Abstract 本示例支持指南概述了GitHub和产品包中包含的所有受支持的TensorRT 7.2.1示例.Tensor ...
- TensorRT IRNNv2Layer
TensorRT IRNNv2Layer IRNNv2Layer层实现递归层,如递归神经网络(RNN).门控递归单元(GRU)和长短期记忆(LSTM).支持的类型有RNN.GRU和LSTM.它执行一个 ...
- JUC 并发编程--12, 使用AtomicInteger 实现一把锁(排队自旋锁), 代码演示
前面 使用自旋锁实现了一把锁,(请看 第5篇) volatile 三大特性: 可见性, 不保证原子性, 禁止指令重排 为了解决 volatile不保证原子性的问题, 引入了原子类, AtomicInt ...
- 计算机网络-ip分类
本网络--网络号全是0(0000 0000)的IP地址是保留地址,意思是"本网络". 环回地址--网络号是127(0111 1111)的IP地址也是保留地址,作为本地环回软件测试. ...
- 查找文件与cron计划任务
查找文件 • 根据预设的条件递归查找对应的文件 find [目录] [条件1] [-a|-o] [条件2] ... -type 类型(f文件.d目录.l快捷方式) -name "文档名称 ...
- 【NX二次开发】NX内部函数,libufunx.dll文件中的内部函数
本文分为两部分:"带参数的函数"和 "带修饰的函数". 浏览这篇博客前请先阅读: [NX二次开发]NX内部函数,查找内部函数的方法 带参数的函数: void e ...
- 打开黑盒:从 MySQL架构设计出发,看它是如何执行一条 SQL语句的
1.把MySQL当个黑盒子一样执行SQL语句 我们的系统采用数据库连接池的方式去并发访问数据库,然后数据库自己其实也会维护一个连接池,其中管理了各种系统跟这台数据库服务器建立的所有连接 当我们的系统只 ...