洛谷P2575高手过招——SG函数初试
题目:https://www.luogu.org/problemnew/show/P2575
第一次用SG函数解决问题,有许多不熟练的地方;
试图按自己的理解写一个dfs,结果错了(连题都没读对,以为是像跳棋一样跳),这样的话用dfs从左往右推就不行了呢;
附上自己的错误尝试:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int maxn=;
int T,n,p,ans,g[];
int dfs(int x)
{
if(g[x])return g[x]-;
int ret=;
for(int i=;i>=;i--)
if(x&(<<i))
{
if((x&(<<(i-)))&&(x&(<<(i-)))==&&i->=)
{
int k=x-(<<i)+(<<(i-));
// if(!dfs(k))
// {
// g[x]=2;
// return 1;
// }
ret^=dfs(k);
}
if((x&(<<(i-)))==&&i->=)
{
int k=x-(<<i)+(<<(i-));
// if(!dfs(k))
// {
// g[x]=2;
// return 1;
// }
ret^=dfs(k);
}
} if(!ret)g[x]=;
else g[x]=;
// printf("%d %d\n",x,g[x]-1);
return g[x]-;
}
int main()
{
scanf("%d",&T);
while(T--)
{
memset(g,,sizeof g);
ans=;
scanf("%d",&n);
for(int i=,m;i<=n;i++)
{
p=;
scanf("%d",&m);
for(int j=,x;j<=m;j++)
{
scanf("%d",&x);
x--;
p|=(<<(-x));
}
// if(ans)continue;
// if(dfs(p)==0)ans=1;
ans^=dfs(p);
}
if(ans)printf("YES\n");
else printf("NO\n");
}
return ;
}
囧
下面是正解,也就是个SG函数的模板;
状压一下每一行,先预处理出来所有状态的SG函数值(注意vis[里面是SG函数值]),然后每次询问异或一下就可以了,还挺简明的。
代码如下:
#include<iostream>
#include<cstdio>
#include<cstring>
using namespace std;
int T,n,m,ans,sg[<<];
bool vis[];
void init(int x)
{
memset(vis,,sizeof vis);
int w=;
for(int i=;i<=;i++)//从小到大对应从右往左
{
int t=(<<(i-));
if(x&t)
{
if(i>&&(x&(t>>))==)
vis[sg[x-t+(t>>)]]=;
// if(i>2&&(x&(t>>1))&&(x&(t>>2))==0)
// vis[sg[x-t+(t>>2)]]=1;//读错题
if((x&(t>>))&&w)
vis[sg[x-t+(<<(w-))]]=;
}
else w=i;
}
int k=;//求mex
while(vis[k])k++;
sg[x]=k;
}
int main()
{
scanf("%d",&T);
for(int i=;i<=(<<)-;i++)init(i);
while(T--)
{
ans=;//!
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d",&m);
int p=;
for(int j=,x;j<=m;j++)
{
scanf("%d",&x);
p|=(<<(-x));
}
ans^=sg[p];
}
if(ans)printf("YES\n");
else printf("NO\n");
}
return ;
}
洛谷P2575高手过招——SG函数初试的更多相关文章
- 洛谷 [P2575] 高手过招
SG函数+状压记忆化搜索 观察题目发现,每一行都是独立的,只要处理出来每一行的SG值,异或起来就好 每一行的SG值可以用状压+记忆化搜索的方法来求,对位运算技术是个很大的考验 注意SG值要预处理出来, ...
- Luogu 2575 高手过招-SG函数
Solution SG函数跑一遍就过了ouo Code #include<cstring> #include<cstdio> #include<algorithm> ...
- 洛谷P1294 高手去散步
洛谷1294 高手去散步 题目背景 高手最近谈恋爱了.不过是单相思.“即使是单相思,也是完整的爱情”,高手从未放弃对它的追求.今天,这个阳光明媚的早晨,太阳从西边缓缓升起.于是它找到高手,希望在晨读开 ...
- 洛谷P2568 GCD (欧拉函数/莫比乌斯反演)
P2568 GCD 题目描述 给定整数N,求1<=x,y<=N且Gcd(x,y)为素数的数对(x,y)有多少对. 输入输出格式 输入格式: 一个整数N 输出格式: 答案 输入输出样例 输入 ...
- P2575 高手过招
传送门 直接搞好像搞不了 考虑转换模型 显然每一行棋子不会跑到其他行.. 所以可以把每一行的情况看成一个子博弈 显然整个答案就是每一行的SG值的异或和 不懂的回去学SG函数... 考虑怎么分析一行的状 ...
- 题解-洛谷P1184 高手之在一起
https://www.luogu.org/problemnew/show/P1184 (题目出处) 见到地名,自然就想到字符串了.可以从第一天开始,将她的位置与高手方便取得地方一一比较,(char字 ...
- Luogu P2575 高手过招
题目链接 \(Click\) \(Here\) 关键在于转换成阶梯\(Nim\)的模型.最开始把题目看错了,理解正确后发现棋子可以向后跳不止一位,那么就比较简单了. 这里把空格看做阶梯,棋子看做硬币, ...
- 洛谷 P1184高手之在一起 题解
题目传送门 那位高手是谁啊?@jxpxcsh QWQ. 这道题数据特别水,所以直接使用O(n*m),每读进一个m内的字符串,就扫一遍n的字符串.但注意地点字符串中有可能会有空格,所以这时候就要请出g ...
- 洛谷——P1294 高手去散步
P1294 高手去散步 题目背景 高手最近谈恋爱了.不过是单相思.“即使是单相思,也是完整的爱情”,高手从未放弃对它的追求.今天,这个阳光明媚的早晨,太阳从西边缓缓升起.于是它找到高手,希望在晨读开始 ...
随机推荐
- windows下安装python、环境设置、多python版本的切换、pyserial与多版本python安装、windows命令行下切换目录
1.windows下安装python 官网下载安装即可 2.安装后的环境设置 我的电脑--属性--高级--设置path的地方添加python安装目录,如C:\Python27;C:\Python33 ...
- Linux最常用的命名
一.环境配置 vim /etc/sysconfig/network-scripts/ifcfg-eth0 vim /etc/sysconfig/network vim /etc/hostname vi ...
- 未能加载文件或程序集“System.EnterpriseServices, Version=4.0.0.0或2.0.0.0
未能加载文件或程序集“System.EnterpriseServices, Version=4.0.0.0, Culture=neutral, PublicKeyToken=b03f5f7f11d50 ...
- MMT事务处理来源类型-INV_OBJECT_GENEALOGY.GETSOURCE
INV_OBJECT_GENEALOGY.GETSOURCE (MTL_MATERIAL_TRANSACTIONS.ORGANIZATION_ID, ...
- redis hash 类型的操作命令
redis 文档: https://redis.readthedocs.io/en/2.4/index.html keys * type key --------------------------- ...
- cocos2d-x-3.6 引擎概述
cocos2d-x是一个游戏开发引擎,从公布到如今也有五六年了,一路看它慢慢壮大.它是如今应用最多的开源2d引擎,没有之中的一个,据说已经占据90%的市场,所以.对于想从事游戏开发的童鞋来说还是有必要 ...
- Android源代码解析之(三)-->异步任务AsyncTask
转载请标明出处:一片枫叶的专栏 上一篇文章中我们解说了android中的异步消息机制. 主要解说了Handler对象的使用方式.消息的发送流程等.android的异步消息机制是android中多任务处 ...
- 有关不同浏览器不同版本号的css以及js计算高度的问题
1.input在全部浏览器以及全部的版本号中,都是定义了高度.然后再定义padding或者border值.这时候都会撑开.高度是本身的高度在padding值和border值 2.select在gool ...
- vue - 前置工作 - 安装vsCode以及插件
开发环境:Win7 x64 开发工具:vsCOde 开发工具vsCode插件配置:Vetur.ivue.Vue 2 Snippets Vetur:强力推荐的一款插件,为什么呢? 格式化代码.高亮.代码 ...
- java开始到熟悉62
(说明:昨天网络出现了问题导致昨天的没有按时上传,这篇算是昨天的,今天晚上照常上传今天的内容) 本次主题:数组拷贝.排序.二分法 1.数组拷贝 a.java.lang中System 类包含一些有用的类 ...