HDU5724


题意

一个 n * 20 的棋盘,棋盘上有若干棋子,Alice 和 Bob 轮流走,
每人每次可以选择任一行的一颗棋子向右移动到最近的一个空格 ;
也就是说如果右边与它相邻的格子里没有棋子,就移到右边与他相邻的格子去;
如果右边与它相邻的格子里 有棋子,就跳过它们移到相邻的空格 ;
一个空格只能放一颗棋子,且不能够放出去。
双方都采取最优策略,最后不能移动棋子的一方输 。

 

 

输入:
第一行输入 t ,表 t 组数据;
第二行输入 n ,表示 棋盘有 n 行;
接下来 n 行,每行包括 m (表示此行有 m 个棋子 )和 m 个数(棋子的位置)

 

输出:
若 Alice 赢,输出“YES” ,否则“NO”。

 

 

解题:

把它看成由 n 个子游戏组成的游戏, 那么整个游戏的 sg 值就是所有子游戏的 sg 值异或起来。
用二进制表示每一行的游戏局面 。 写完这题 感觉对状态压缩又多了解了一点点~~

(写的时候SB了一下,sg数组开小了= = 不造错哪又纠结了很久,不过也因为这样,想了很久这个问题,印象更深刻= =)

 

#include<cstdio>
#include<cstring>
#include<algorithm>
#include<iostream>
#include<string>
using namespace std;
const int maxn = 1050000;
int num[25],sg[maxn];
void getsg()
{for(int i=1;i<(1<<20);i++){int hash[50] = {0}, r=-1;for(int j=0;j<20;j++){if( !((i>>j) & 1)) r = j;if( (i>>j) & 1){if(r != -1)hash[ sg[i ^ (1<<j) ^ (1<<r)]] = 1;}}int j = 0;while(hash[j]!=0) j++;sg[i] = j; }
}
int main()
{int t,n,m,loc; getsg(); scanf("%d",&t);while(t--){scanf("%d",&n); int ans = 0;for(int i=0;i<n;i++){scanf("%d",&m);   num[i] = 0;   for(int j=0;j<m;j++){scanf("%d",&loc);num[i] ^=  (1<<(20-loc));  }ans ^= sg[ num[i] ];}printf(ans?"YES\n":"NO\n");}return 0;
}

 

转载于:https://www.cnblogs.com/ember/p/5720836.html

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

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

相关文章

C语言代码规范(九)运算符优先级使用括号提高阅读性

举简单例子 a b | c << d 2; 对于大牛没有问题&#xff0c;对于我这样的码农需要思考一下运算优先级 对于这种情况华某有规范使用括号来表示运算顺序&#xff0c;从而提高代码可阅读性 a b | ( c << (d 2) ); 这样一目了然&#xff0c;大家好才是真的好。…

linux 内存取证_【取证流程】电子数据证据远程勘验

原创&#xff1a;弘连网络电子数据证据远程勘验在日常的取证工作中必不可少&#xff0c;但由于存在信息安全差、数据可能被篡改的问题。取证过程中&#xff0c;有明确的取证要求来确保取证过程的规范显得至关重要&#xff0c;今天我们就一起来回顾下遇到远程勘验的取证场景&…

OSGi –带有服务的简单Hello World

在本文中&#xff0c;我们将使用OSGi开发一个简单的Hello World应用程序。 我们将使用Felix作为OSGi容器 。 在下一篇文章中&#xff0c;我们将继续使用该应用程序&#xff0c;并使用Spring Dynamic Modules对其进行改进。 为了使开发有趣&#xff0c;我们将创建两个捆绑包&…

Shell - 特殊变量

$0 表示所执行程序的路径名。 [hueyhuey-K42JE ~]$ ll ~/bin total 4 -rwxrwxr-x 1 huey huey 21 Oct 24 14:39 hello [hueyhuey-K42JE ~]$ cat ~/bin/hello #!/bin/bashecho $0: $0 [hueyhuey-K42JE ~]$ hello /home/huey/bin/hello [hueyhuey-K42JE ~]$ $n 表示传递给脚本…

jquery技巧

返回顶部按钮 利用 jQuery 中的 animate 和 scrollTop 方法&#xff0c;你无需插件就可以创建简单的 scroll up 效果: // 返回顶部 $(a.top).click(function (e) { e.preventDefault();//ff下阻止滚动条默认行为 $(document.body).animate({scrollTop: 0}, 800); }); <a cla…

串口不通或乱码,排查方法

硬件问题&#xff1a; 1、USB转串口工具有问题&#xff0c;换一个工具试试&#xff08;用久了很容易坏的东西&#xff09; 2、外部晶振有问题 3、单片机和外设的TX、RX连接电路上是否增加了元器件&#xff1f;比如0欧姆电阻。去掉以后是否能通&#xff1f;&#xff08;遇到过一…

python复制粘贴快捷键_PyCharm入门教程——剪切、复制和粘贴|python基础教程|python入门|python教程...

PyCharm提供了许多方便的剪贴板操作。您可以复制、剪切和粘贴所选文本、文件路径或对符号或代码行的引用。 因为PyCharm使用系统剪贴板&#xff0c;所以可以在应用程序之间复制和粘贴。因此&#xff0c;在粘贴剪贴板条目时&#xff0c;PyCharm会从文本中删除任何格式&#xff0…

夺命雷公狗---无限级分类NO6

<?phpheader("Content-Type:text/html;charsetutf-8");$aarr array(array(id>1,name>安徽,pid>0),array(id>2,name>海淀,pid>7),array(id>3,name>浣溪县,pid>5),array(id>4,name>昌平,pid>7),array(id>5,name>淮北,p…

Spring&Quartz集成自定义注释

我们知道Spring支持与Quartz框架集成。 但是到目前为止&#xff0c;Spring仅支持静态XML声明方法。 如果想了解如何将Spring与Quartz集成&#xff0c;可以参考Spring Quartz JavaMail集成教程 。 作为宠物项目要求的一部分&#xff0c;我必须动态安排工作&#xff0c;并且想…

Android 服务

Android服务是Android应用程序的一类可以异步运行的组件 要创建自己的服务类&#xff0c;需要派生Service类&#xff0c;并至少用自定义代码实现onCreate()、onStart()、onDestory()这几个方法。此外还必须在 AndroidManifest.XML文件中用<service>标签表明你的服务 <…

单片机/嵌入式软件架构分层思想

以STM32裸机开发为例。 软件分层应用层驱动层硬件层固件层 ①最底层为固件层&#xff0c;Firmware 这一层通常是官方给的库&#xff0c;库函数对寄存器进行操作&#xff0c;例如&#xff1a; /*** brief Transmits a Data through the SPIx/I2Sx peripheral.* param SPIx: …

玩! 框架:为什么我会爱上它

前一段时间&#xff0c;我是房地美&#xff0c;房地美&#xff0c;Foreclosure.com和HUD等公司在房地产市场上进行一些大型部署的技术负责人。 我们运行的是您可能熟悉的传统企业Java堆栈-Spring &#xff0c; Hibernate &#xff0c;Solr等。花了几年时间&#xff0c;但我们建…

关于在移动网页中图片自适应大小的写法

一般在移动网页时&#xff0c;图片属性写成如下就可以达到自适应大小 <style type"text/css"> .nameg{background: rgba(000,000,000,0.6);} .nameg div{float: left;} .nameg .a1{width: 10%;background:#000000;} .nameg .a1 img{width: 100%;height: 10…

python2 print_Python2和Python3中print的不同点

在Python2和Python3中都提供print()方法来打印信息,但两个版本间的print稍微有差异 主要体现在以下几个方面&#xff1a; 1.python3中print是一个内置函数&#xff0c;有多个参数&#xff0c;而python2中print是一个语法结构&#xff1b; 2.Python2打印时可以不加括号&#xff…

java 与 c#的 中 字符串比较“==”与“equals”的差异

.net中&#xff0c;其字符串特有的驻留机制&#xff0c;保证了在同一进程中&#xff0c;相同字符序列的字符串&#xff0c;只有一个实例&#xff0c;这样能避免相同内容的字符串重复实例化&#xff0c;以减少性能开销。 先来回顾一下c#中的代码&#xff1a; public static void…

visual studio 2019 未能在命名空间“System.IO.Ports”中找到类型名“SerialPort”

在vs2019以前的版本&#xff0c;只要using System.IO.Ports就可以用SerialPort。 这里需要自己手动添加相关引用。 工具–>Nuget包管理器&#xff08;N&#xff09;–>管理解决方案的Nuget程序包&#xff08;N&#xff09; –>浏览&#xff0c;左边搜索SerialPort 右…

单一登录云:SAML和OpenId

当访问不同组织拥有的不同应用程序时&#xff0c;每次从一个应用程序转到另一个应用程序时都必须进行身份验证。 不仅浪费时间&#xff0c;而且您还必须记住多个经常丢失的密码。 单一登录是一次认证的能力&#xff0c;并且能够使用已认证的身份在应用程序之间无缝切换。 在In…

python开发环境功能介绍_第一模块 第3章 Python介绍与环境配置

python入门(全为重点) 1. 编程语言介绍 编程语言分类、总结 2. python介绍 3. 解释器多版本共存 4. 运行python程序的两种方式 5. 一个python程序运行的三个步骤&#xff08;******&#xff09; 6. 注释 7. IED集成开发环境 3.1 编程语言分类之低级语言 这里的高级/低级指的是离…

如何判断微信内置浏览器(JS PHP)

进行微信公众账号开发的时候&#xff0c;其中很大一块是微站点的开发&#xff0c;我们需要知道当前的浏览器是微信内置的浏览器&#xff0c;那么如何判断呢&#xff1f; 微信内置浏览器的 User Agent Mozilla/5.0 (iPhone; CPU iPhone OS 6_1_3 like Mac OS X) AppleWebKit/536…

用WPF做关于MEF 简单学习记录

写在前面&#xff1a;下面学习所得多是从自http://www.cnblogs.com/comsokey/p/MEF1.html和http://www.cnblogs.com/yunfeifei/p/3922668.html两位大神的文章里学到的&#xff0c;特别鸣谢&#xff01;整理下是更大一方面是对自己知识的梳理&#xff0c;用词用句不够准确&#…