UVA12163 游戏
题目大意
现在有两个人在一个n个结点的有向图上玩一个双人游戏,保证图中无环和自圈。游戏的规则如下:
1.初始的时候$i$号点有一个正权值$value_i$
2.两名玩家依次操作,每个玩家在当前回合可以选择一个具有如下性质的点
-该点的权值为正
-该点具有至少一条出边
如果不存在这样子的点,那么当前回合的玩家输掉整局游戏
3.当某名玩家选定一个点以后,将该点的$value$减一,并将$K_i$个该点出边连向的点的$value$加一,这$K_i$个点由当前玩家选择,并允许选择重复的点。
现在给出整个有向图和$K_i$,每次询问给定每个点的$value$,判断先手玩家是否存在必胜策略。
$n\leq 100$,每个点的出边数量不超过$17$。
题解
由于每一步操作只令$value_i$的值$-1$,所以可以把“在$x$点有$1$的权值”看做“以$x$点为起点开始一局游戏”。
考虑在$x$点做两局游戏一定是后手赢,因为不论执先手的人在某一局子游戏进行操作,后手只需要在另一局进行对称操作即可。
所以只关心$value$的奇偶性。
由于每一个点的出边不超过$17$,所以以一个点为起点的子游戏,其后继是可枚举的。
具体的,对于没有出边的点$x,Sg_x=0$。
否则枚举每一条出边是否改变出边指向的点$y$的游戏的次数的奇偶性,将游戏次数奇偶性被改变的后继的点集记为$S$,设这$S$个点的$Sg$值的异或和为$F_S$,则$$Sg_x=mex\{F_S\}(|S|\leq K_i,|S|\equiv K_i\mod x)$$
即枚举每一个$x$点出发能到达的所有后继状态,每一个后继状态都有若干个子游戏组成,其根据$Sg$定理,$Sg$值为每一个子游戏的$Sg$值异或和,所以对所有个后继状态$Sg$值求$mex$即可。
对于每一次询问,对于所有的$x$满足以$x$点进行了奇数次游戏,则将这些$Sg_x$异或起来和,若为$0$则先手必败,负责先手必胜。
复杂度为$O(T(2^{17}n+Qn))$
#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<cmath>
#define LL long long
#define M 200
#define N 540000
using namespace std;
int read(){
int nm=0,fh=1; int cw=getchar();
for(;!isdigit(cw);cw=getchar()) if(cw=='-') fh=-fh;
for(;isdigit(cw);cw=getchar()) nm=nm*10+(cw-'0');
return nm*fh;
}
int n,m,sz[M],to[M][20],tmp,K[M],val,sg[M],bt[N],G[N],F[N];
void link(int x,int y){to[x][++sz[x]]=y;} bool vs[N];
void DP(int x){
if(sg[x]!=-1) return; if(!sz[x]){sg[x]=0;return;}
for(int i=1;i<=sz[x];i++) DP(to[x][i]);
for(int i=1;i<=sz[x];i++) G[1<<(i-1)]=sg[to[x][i]];
int MAXN=(1<<sz[x]); F[0]=sg[x]=0;
for(int i=1;i<MAXN;i++) F[i]=(F[i^(i&(-i))]^G[i&(-i)]);
for(int i=0;i<MAXN;i++) if(bt[i]<=K[x]&&!((K[x]^bt[i])&1)) vs[F[i]]=true;
while(vs[sg[x]]) ++sg[x]; for(int i=0;i<MAXN;i++) vs[F[i]]=false;
}
int main(){
for(int i=1;i<(1<<19);i++) bt[i]=bt[i>>1]+(i&1);
memset(vs,false,sizeof(vs));
for(int Qs=read(),nq=1;nq<=Qs;nq++,putchar('\n')){
printf("Game#%d:\n",nq),memset(sg,-1,sizeof(sg));
n=read(),m=read(),memset(sz,0,sizeof(sz));
for(int i=1;i<=m;i++){int x=read(),y=read();link(x+1,y+1);}
for(int i=1;i<=n;i++) K[i]=read();
for(int i=1;i<=n;i++) DP(i);
for(int rm=1,rs=0,Qr=read();rm<=Qr;rm++,rs=0){
for(int i=1;i<=n;i++) val=read(),rs^=((val&1)*sg[i]);
printf("Round#%d: ",rm),puts(rs?"WINNING":"LOSING");
}
}
return 0;
}
UVA12163 游戏的更多相关文章
- 使用HTML5开发Kinect体感游戏
一.简介 我们要做的是怎样一款游戏? 在前不久成都TGC2016展会上,我们开发了一款<火影忍者手游>的体感游戏,主要模拟手游章节<九尾袭来 >,用户化身四代,与九尾进行对决, ...
- jQuery实践-网页版2048小游戏
▓▓▓▓▓▓ 大致介绍 看了一个实现网页版2048小游戏的视频,觉得能做出自己以前喜欢玩的小游戏很有意思便自己动手试了试,真正的验证了这句话-不要以为你以为的就是你以为的,看视频时觉得看懂了,会写了, ...
- Unity游戏内版本更新
最近研究了一下游戏内apk包更新的方法. ios对于应用的管理比较严格,除非热更新脚本,不太可能做到端内大版本包的更新.然而安卓端则没有此限制.因此可以做到不跳到网页或应用商店,就覆盖更新apk包. ...
- 游戏服务器菜鸟之C#初探一游戏服务
本人80后程序猿一枚,原来搞过C++/Java/C#,因为工作原因最后选择一直从事C#开发,因为读书时候对游戏一直比较感兴趣,机缘巧合公司做一个手游的项目,我就开始游戏服务器的折腾之旅. 游戏的构架是 ...
- iOS审核这些坑,腾讯游戏也踩过
作者:Jamie,专项技术测试工程师,在iOS预审和ASO优化领域从事专项测试相关工作,为腾讯游戏近100个产品提供专项服务. WeTest 导读 在App上架苹果应用商店的过程中,相信大多数iOS开 ...
- 漫谈C#编程语言在游戏领域的应用
0x00 前言 随着微软越来越开放,C#也变得越来越吸引人们的眼球.而在游戏行业中,C#也开始慢慢地获得了关注.这不, 网易绝代双娇手游团队已经全面使用.Net Core支持前后端统一C#开发,跨平台 ...
- 解构C#游戏框架uFrame兼谈游戏架构设计
1.概览 uFrame是提供给Unity3D开发者使用的一个框架插件,它本身模仿了MVVM这种架构模式(事实上并不包含Model部分,且多出了Controller部分).因为用于Unity3D,所以它 ...
- 趣说游戏AI开发:曼哈顿街角的A*算法
0x00 前言 请叫我标题党!请叫我标题党!请叫我标题党!因为下面的文字既不发生在美国曼哈顿,也不是一个讲述美国梦的故事.相反,这可能只是一篇没有那么枯燥的关于算法的文章.A星算法,这个在游戏寻路开发 ...
- 拼图小游戏之计算后样式与CSS动画的冲突
先说结论: 前几天写了几个非常简单的移动端小游戏,其中一个拼图游戏让我郁闷了一段时间.因为要获取每张图片的位置,用`<style>`标签写的样式,直接获取计算后样式再用来交换位置,结果就悲 ...
随机推荐
- 替换jar包内指定的文件
用Java jar 工具来替换. ① jar uvf test.jar test.class 把test.class 直接添加到jar包的根目录,也就是替换到根目录文件. ②jar uvf test. ...
- 【python】-- 深浅copy、集合
深浅copy 1.数字.字符串的copy: 赋值(=).浅拷贝(copy)和深拷贝(deepcopy)其实都一样,因为它们永远指向同一个内存地址: >>> import copy & ...
- 【python】-- web开发之JavaScript
JavaScript JavaScript是一门编程语言,浏览器内置了JavaScript语言的解释器,所以在浏览器上按照JavaScript语言的规则编写相应代码之,浏览器可以解释并做出相应的处理. ...
- Delphi窗体研究,留个爪,以后回来研究
Delphi - 窗体创建过程 来自大富翁. 1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 ...
- postgres=# psql -U postgres -h 127.0.0.1 -p 5432 -d dreamstart_dev -w
postgres=# psql -U postgres -h 127.0.0.1 -p 5432 -d dreamstart_dev -wpostgres-# \dNo relations found ...
- PHP中ob系列函数讲解(浏览器缓存技术) (转)
Output Control 函数可以让你自由控制脚本中数据的输出.它非常地有用,特别是对于:当你想在数据已经输出后,再输出文件头的情况. 输出控制函数不对使用 header() 或 setcooki ...
- Smarty模板的逻辑运算符号稍微做一下总结
对Smarty模板的逻辑运算符号稍微做一下总结,以备后用. eq equal : 相等neq not equal:不等于gt greater than:大于lt less th ...
- 关于 IN UPDATE TASK
[转 http://blog.sina.com.cn/s/blog_6f74e6d50100sq57.html]更新程序必须用一个特殊的FM(update module)来实现. 1.Exportin ...
- JVM性能优化, Part 5 Java的伸缩性
很多程序员在解决JVM性能问题的时候,花开了很多时间去调优应用程序级别的性能瓶颈,当你读完这本系列文章之后你会发现我可能更加系统地看待这类的问题.我说过JVM的自身技术限制了Java企业级应用的伸缩性 ...
- Xen虚拟化基础篇
一.xen的简介 Xen是一个开放源代码虚拟机监视器,由剑桥大学开发.它打算在单个计算机上运行多达128个有完全功能的操作系统. 在旧(无虚拟硬件)的处理器上执行Xen,操作系统必须进行显式地修改(& ...