【luogu P2148】 ED(SG函数)

参考另一位dalao的文章,无恶意

学习博弈论也可返回另一篇笔记

题目描述

小 E 与小 W 进行一项名为 E&D 游戏。

游戏的规则如下:桌子上有 2 n 2n 2n 堆石子,编号为 1 ∼ 2 n 1 \sim 2n 12n。其中,为了方便起见,我们将第 2 k − 1 2k-1 2k1 堆与第 2 k 2k 2k 堆( 1 ≤ k ≤ n 1 \le k \le n 1kn)视为同一组。第 i i i 堆的石子个数用一个正整数 S i S_i Si 表示。

一次分割操作指的是,从桌子上任取一堆石子,将其移走。然后分割它同一组的另一堆石子,从中取出若干个石子放在被移走的位置,组成新的一堆。操作完成后,所有堆的石子数必须保证大于 0 0 0。显然,被分割的一堆的石子数至少要为 2 2 2。两个人轮流进行分割操作。如果轮到某人进行操作时,所有堆的石子数均为 1 1 1,则此时没有石子可以操作,判此人输掉比赛。

小 E 进行第一次分割。他想知道,是否存在某种策略使得他一定能战胜小 W。因此,他求助于小 F,也就是你,请你告诉他是否存在必胜策略。例如,假设初始时桌子上有 4 4 4 堆石子,数量分别为 1 , 2 , 3 , 1 1,2,3,1 1,2,3,1。小 E 可以选择移走第 1 1 1 堆,然后将第 2 2 2 堆分割(只能分出 1 1 1 个石子)。接下来,小 W 只能选择移走第 4 4 4 堆,然后将第 3 3 3 堆分割为 1 1 1 2 2 2。最后轮到小 E,他只能移走后两堆中数量为 1 1 1 的一堆,将另一堆分割为 1 1 1 1 1 1。这样,轮到小 W 时,所有堆的数量均为 1 1 1,则他输掉了比赛。故小 E 存在必胜策略。

输入格式

本题有多组数据。

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

对于每组数据:

第一行一个整数 N N N,表示桌子上共有 N N N 堆石子,这里的 N N N 即为题目描述中的 2 n 2n 2n

第二行 N N N 个整数 S 1 … N S_{1 \dots N} S1N

输出格式

对于每组数据,如果小 E 必胜,则一行一个字符串 YES,否则一行一个字符串 NO

样例 #1

样例输入 #1

2
4
1 2 3 1
6
1 1 1 1 1 1

样例输出 #1

YES
NO

提示

对于 20 % 20\% 20% 的数据, N = 2 N=2 N=2

对于另外 20 % 20\% 20% 的数据, N ≤ 4 N \le 4 N4 S i ≤ 50 S_i \le 50 Si50

对于 100 % 100\% 100% 的数据, 1 ≤ T ≤ 20 1 \le T \le 20 1T20 1 ≤ N ≤ 2 × 1 0 4 1 \le N \le 2 \times 10^4 1N2×104 N N N 为偶数, 1 ≤ S i ≤ 2 × 1 0 9 1 \le S_i \le 2 \times 10^9 1Si2×109

基本思路

这道题又会被恶心到了,但也不差这一次了吧。

S G SG SG 函数玩弄这么久,我们应该有一种觉悟,即一个状态应该被单独考虑,因为到最后各个 S G SG SG 值都会被异或起来,故而应该将每个点单独考虑,而不是将一整个联合的局面作为状态考虑

这题是不是可以用状压做

那么就明晰了,我们不必为一排石子哪个被操作过而烦恼,我们把每个石子单独拿出来考虑。

依照题意,对于单独的石子而言,它会被分割成两堆,因为另一堆去掉了就没有了。那么分割出来的这两堆就是它的后继状态,但是注意是这两堆共同构成了它的一个后继状态,所以不能直接将它们的 S G SG SG 值异或起来

那么怎么计算呢?我们不是在计算每一堆时都会开一个 v i s vis vis 数组记录后继哪些 S G SG SG 值出现过吗?那么我们直接将他们开成 b i t s e t bitset bitset 压缩空间,还可以直接进行或操作,因为两堆共同构成后继状态的话,我们要取它的并集才可以进行 m e x mex mex 运算。最后参考学习笔记中的第二题,循环枚举分割成什么数量的两堆就可以了。

贡献上我的 30 30 30 分代码。

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N=100;
int t,n,sg[N],a[N],ans;
bitset<N> s[N];
inline int mex(bitset<N> x){int i=0;while(x[i]) i++;return i;
}
int main(){ios::sync_with_stdio(false);for(int i=2;i<=70;i++){for(int j=1,k=i-1;k;j++,k--)s[i].set(mex(s[j]|s[k]));}cin>>t;while(t--){cin>>n;ans=0;for(int i=1;i<=n;i++){cin>>a[i];if(i%2==0)ans^=mex(s[a[i]]|s[a[i-1]]);}if(ans) puts("YES");else puts("NO");}return 0;
}

特别注意不能直接将一组中两堆的数量加起来使用它的 S G SG SG 值,因为 S G SG SG值的话代表它的分割是没确定的,而一组中的分割是确定的。

为什么只有 30 30 30 分?因为题目的数据范围支撑不了。显然碰到这种情况想想我们博弈论有哪两项传统技能?那就是打表预处理和打表观察了,上面这个就是打表代码。

这种题目不要想着预处理了,我们把每个数的 v i s vis vis (代码中的 s s s 数组)导出来看看()。

1: 00000000000000000000
2: 00000000000000000001
3: 00000000000000000010
4: 00000000000000000011
5: 00000000000000000100
6: 00000000000000000101
7: 00000000000000000110
8: 00000000000000000111
9: 00000000000000001000
10: 00000000000000001001
11: 00000000000000001010
12: 00000000000000001011
13: 00000000000000001100
14: 00000000000000001101
15: 00000000000000001110
16: 00000000000000001111
17: 00000000000000010000
18: 00000000000000010001
19: 00000000000000010010
20: 00000000000000010011

我们可以轻而易举地发现 i i i v i s vis vis 就是 i − 1 i-1 i1 的二进制表示。

那就十分容易了。

核心代码

待补

咕咕咕

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/57146.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

雷池WAF自动化实现安全运营实操案例终极篇

免责声明 本教程仅为合法的教学目的而准备&#xff0c;严禁用于任何形式的违法犯罪活动及其他商业行为&#xff0c;在使用本教程前&#xff0c;您应确保该行为符合当地的法律法规&#xff0c;继续阅读即表示您需自行承担所有操作的后果&#xff0c;如有异议&#xff0c;请立即停…

OpenShift 4 - 云原生备份容灾 - Velero 和 OADP 基础篇

《OpenShift 4.x HOL教程汇总》 说明&#xff1a; 本文主要说明能够云原生备份容灾的开源项目 Velero 及其红帽扩展项目 OADP 的概念和架构篇。操作篇见《OpenShift 4 - 使用 OADP 对容器应用进行备份和恢复&#xff08;附视频&#xff09; 》 Velero 和 OADP 包含的功能和模…

JS中的toFixed()

最近使用到一个方法&#xff0c;有点特殊&#xff0c;记录下。toFixed() 它的返回值是字符串&#xff0c;在计算时需要注意。它的保留小数使用的是银行家算法&#xff0c;这里简单记录一下。 银行家舍入&#xff1a;所谓银行家舍入法&#xff0c;其实质是一种四舍六入五取偶&a…

干货|react router- loader 和组件 useEffect 加载数据的选择

loader 的优点&#xff1a; 集中式数据加载&#xff1a; 通过路由配置直接管理数据加载逻辑&#xff0c;将路由与数据需求紧密结合&#xff0c;减少组件中的逻辑复杂度。适合大型应用&#xff0c;在多级路由和页面跳转时更好地管理数据加载逻辑&#xff0c;避免在组件中重复处理…

three.js 毛玻璃着色器的效果

three.js 毛玻璃着色器的效果 在线链接&#xff1a;https://threehub.cn/#/codeMirror?navigationThreeJS&classifyshader&idgroundglass 国内站点预览&#xff1a;http://threehub.cn github地址: https://github.com/z2586300277/three-cesium-examples import…

MySQL基础笔记小结

1. mysql : 1.1启动与停止mysql&#xff1a; net start mysql80 net stop mysel80 1.2客户端连接&#xff1a; 2种,系统cmd与自带的cmd&#xff08;直接打开&#xff09; mysql -u root-p 1.2.1 数据存储 RDBMS&#xff1a;关系型数据库&#xff1a;建立在关系模型基础上&…

在海外留学/工作,如何报考微软mos认证?

重点首先得强调的是&#xff0c;即使在海外也可以顺利地在国内获取微软MOS认证&#xff01; 01 微软mos认证简介 Microsoft Office Specialist 简称MOS。是微软公司和第三方国际认证机构、全球三大IT测验与教学中心之一的思递波/Certiport公司于1997年联合推出的&#xff0c;…

[python]numpy和numpy+mkl区别

NumPy是Python中一个开源的科学计算库&#xff0c;它使得Python能够支持大量的数组或者矩阵运算&#xff0c;以及其他科学计算上常用的函数。而NumPyMKL&#xff08;Intel Math Kernel Library&#xff09;则是在NumPy的基础上加入了Intel Math Kernel Library&#xff08;MKL&…

python爬虫,爬取网页壁纸图片

python爬虫实战&#xff0c;爬取网页壁纸图片 使用python爬取壁纸图片&#xff0c;保存到本地。 爬取彼岸图网&#xff0c;网站地址https://pic.netbian.com/ 本人小白&#xff0c;记录一下学习过程。 开始前的准备 安装python环境&#xff0c;略。 python编辑器pycharm2…

WPF入门_03路由事件

1、如何定义路由事件 1)事件定义 public static readonly RoutedEvent ClickEvent; 2)事件注册,Button按钮的Click事件是继承于ButtonBase基类的 ClickEvent = EventManager.RegisterRoutedEvent("Click", RoutingStrategy.Bubble, typeof(RoutedEven…

ThinkPad T480拆机屏幕改装:便携式显示器DIY指南

ThinkPad T480拆机屏幕改装&#xff1a;便携式显示器DIY指南 本文记录了将旧笔记本电脑 T480 拆机屏幕改装为便携式显示器的全过程。作者在决定升级设备后&#xff0c;选择通过 DIY 方式利用原有的屏幕资源。文章详细介绍了屏幕驱动板的安装、螺丝孔的剪裁、排线连接及固定的步…

[AWS]RDS数据库版本升级

背景&#xff1a;由于AWS上mysql5.7版本不再支持&#xff0c;需要进行版本升级。 吐槽&#xff1a;每年都要来那么几次&#xff0c;真的有病一样&#xff0c;很烦。 步骤一、升级检查 AWS提供了一个python的升级检测脚本&#xff0c;可以按照一下脚本下载测试&#xff1a; [r…

本地缓存少更改、小数据、低一致表的思考

对于那些少更改、小数据的表&#xff0c;以及对一致性要求不高的业务&#xff0c;其实完全可以通过本地缓存将表数据缓存到本地内存中&#xff0c;然后通过定时机制拉取表更新数据 直接从内存中获取数据&#xff0c;将会使得查询性能得到巨大的提升&#xff0c;并且由于更改少…

Kibana可视化Dashboard如何基于字段是否包含某关键词进行过滤

kinana是一个功能强大、可对Elasticsearch数据进行可视化的开源工具。 我们在dashboard创建可视化时&#xff0c;有时需要将某个index里数据的某个字段根据是否包含某些特定关键词进行过滤&#xff0c;这个时候就可以用到lens里的filter功能很方便地进行操作。 如上图所示&…

架构师备考-背诵精华(系统架构评估)

系统架构评估是在对架构分析、评估的基础上&#xff0c;对架构策略的选取进行决策。它利用数学或逻辑分析技术&#xff0c;针对系统的一致性、正确性、质量属性、规划结果等不同方面&#xff0c;提供描述性、预测性和指令性的分析结果。 重要概念 敏感点&#xff1a;敏感点是…

大数据面试题整理——MapReduce

系列文章目录 第一章 HDFS面试题 第二章 MapReduce面试题 文章目录 系列文章目录一、请简要解释一下 MapReduce 的工作原理。二、什么是 map 函数和 reduce 函数&#xff1f;它们的作用分别是什么&#xff1f;三、如何处理数据倾斜问题在 MapReduce 中&#xff1f;四、在 MapR…

docker 下载netcore 镜像

dotnet-docker/README.runtime.md at main dotnet/dotnet-docker GitHub docker pull mcr.microsoft.com/dotnet/runtime:8.0 docker pull mcr.microsoft.com/dotnet/runtime:3.1

二分查找算法 (算法详解+模板+例题)

文章目录 二分查找算法简介1.朴素的二分查找2. 在排序数组中查找元素的第一个和最后一个位置3. 搜索插入位置4. 山脉数组的峰顶索引5.寻找峰值6. 寻找旋转排序数组中的最小值 二分查找算法简介 二分查找算法并不是针对在数组有序的情况下,通过后面的题我们就会知道实际上只要是…

【存储设备专栏 2.2 -- linux 下 fdisk -l 命令详细介绍2 】

文章目录 实例详解 fdisk -l第一部分&#xff1a;磁盘 /dev/sda详细解释&#xff1a; 第二部分&#xff1a;环回设备 /dev/loop8详细解释&#xff1a; 总结 实例详解 fdisk -l 在 Linux 系统中执行 fdisk -l 命令会输出详细的磁盘和分区信息。下面我们具体解释一下下面的log每…