Codeforces 786A Berzerk(博弈论)
【题目链接】 http://codeforces.com/problemset/problem/786/A
【题目大意】
有两个人,每个人有一个数集,里面有一些数,现在有一个环,有个棋子放在1,
有个不确定位置的终点,两个人轮流从自己的数集中选择一个数,作为这个棋子移动的步数
问终点在不同位置,不同人先手的时候谁能赢,或者游戏陷入循环
【题解】
我们从st_0_0=st_1_0=0开始倒着推导,
如果一个状态是必败态,那么它的前继节点一定是必胜态
如果一个点的所有后继都是必胜态,那么这个节点一定是必败态。
每当一个点被其必胜后继推导到,那么其度数减一,当度数为0时则表示其为必败态
我们根据这些结论倒着推导每个状态的答案并记录,最后按顺序输出即可。
【代码】
#include <cstdio>
#include <vector>
#include <cstring>
#include <string>
using namespace std;
const int N=100010;
int n,sg[2][N],d[2][N],k,x;
vector<int> g[2];
int dfs(int k,int pos,int v){
int &ret=sg[k][pos];
if(~ret)return ret;
ret=v;
if(v==0){
for(int i=0;i<g[k^1].size();i++){
int x=g[k^1][i];
int j=(pos+n-x)%n;
if(j==0)continue;
dfs(k^1,j,1);
}
}else{
for(int i=0;i<g[k^1].size();i++){
int x=g[k^1][i];
int j=(pos+n-x)%n;
if(j==0)continue;
if(--d[k^1][j]==0)dfs(k^1,j,0);
}
}return ret;
}
int main(){
scanf("%d",&n);
for(int i=0;i<2;i++){
scanf("%d",&k);
g[i].clear();
while(k--){
scanf("%d",&x);
g[i].push_back(x);
}for(int j=1;j<n;j++)d[i][j]=g[i].size();
}memset(sg,-1,sizeof(sg));
dfs(0,0,0);
dfs(1,0,0);
string s[3]={"Loop","Lose","Win"};
for(int k=0;k<2;k++){
for(int i=1;i<n;i++){
printf("%s%c",s[sg[k][i]+1].c_str(),i+1==n?'\n':' ');
}
}return 0;
}
Codeforces 786A Berzerk(博弈论)的更多相关文章
- [刷题]Codeforces 786A - Berzerk
http://codeforces.com/problemset/problem/786/A Description Rick and Morty are playing their own vers ...
- cf786a
title: CodeForces 786A Berzerk data: 2018-3-3 10:29:40 tags: 博弈论 bfs 无限 with draw copyright: true ca ...
- ACM 博弈(难)题练习 (第一弹)
第二弹: 套路&&经验总结: 1. N堆***的游戏,一般可以打表找SG函数的规律.比如CodeForces 603C 2.看起来是单轮的游戏,实际上可能拆分成一些独立的子游戏.比如C ...
- Codeforces Round #406 (Div. 1) A. Berzerk 记忆化搜索
A. Berzerk 题目连接: http://codeforces.com/contest/786/problem/A Description Rick and Morty are playing ...
- [Codeforces 1191D] Tokitsukaze, CSL and Stone Game(博弈论)
[Codeforces 1191D] Tokitsukaze, CSL and Stone Game(博弈论) 题面 有n堆石子,两个人轮流取石子,一次只能从某堆里取一颗.如果某个人取的时候已经没有石 ...
- codeforces 1451D,一道有趣的博弈论问题
大家好,欢迎来到codeforces专题. 今天选择的问题是Contest 1451场的D题,这是一道有趣简单的伪博弈论问题,全场通过的人有3203人.难度不太高,依旧以思维为主,坑不多,非常友好. ...
- Codeforces 1411G - No Game No Life(博弈论+生成函数+FWTxor)
Codeforces 题面传送门 & 洛谷题面传送门 一道肥肠套路的题目. 首先这题涉及博弈论.注意到这里每一个棋子的移动方式都是独立的,因此可以考虑 SG 定理.具体来说,我们先求出每个棋子 ...
- Codeforces 1458E - Nim Shortcuts(博弈论+BIT)
Codeforces 题目传送门 & 洛谷题目传送门 首先看到这样的题我们不妨从最特殊的情况入手,再逐渐推广到一般的情况.考虑如果没有特殊点的情况,我们将每个可能的局面看作一个点 \((a,b ...
- Codeforces 549C. The Game Of Parity[博弈论]
C. The Game Of Parity time limit per test 1 second memory limit per test 256 megabytes input standar ...
随机推荐
- [zhuan]Android安全讲座第九层(二) 内存dump
http://sunzeduo.blog.51cto.com/2758509/1409450 近来android上越来越多的应用对自身的保护机制加强了重视,主要表现在几个方面. 1 dex加壳 2 s ...
- 配置Tomcat时server.xml和content.xml自动还原问题
当我们在处理中文乱码或是配置数据源时,我们要修改Tomcat下的server.xml和content.xml文件. 但是当我们修改完后重启Tomcat服务器时发现xml文件又被还原了,修改无效果. 为 ...
- Eclipse开发环境配置,打磨Eclipse,安装插件(适用3.4,3.5,3.6,3.7)
转载自:http://elf8848.iteye.com/blog/354035 打磨Eclipse -- 磨刀不误砍柴工 -------------------------------------- ...
- c++(类继承)示例[仅用于弱弱的博主巩固知识点用哦,不好勿喷]
测试代码: Animals.h: #pragma once #include<string> class Animals { protected: std::string Food; in ...
- js 禁止鼠标和键盘行为
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- 随机洗牌算法Knuth Shuffle和错排公式
Knuth随机洗牌算法:譬如现在有54张牌,如何洗牌才能保证随机性.可以这么考虑,从最末尾一张牌开始洗,对于每一张牌,编号在该牌前面的牌中任意一张选一张和当前牌进行交换,直至洗到第一张牌为止.参考代码 ...
- Codeforces Round #301 解题报告
感觉这次的题目顺序很不合理啊... A. Combination Lock Scrooge McDuck keeps his most treasured savings in a home sa ...
- [BZOJ2190&BZOJ2705]欧拉函数应用两例
欧拉函数phi[n]是表示1~n中与n互质的数个数. 可以用公式phi[n]=n*(1-1/p1)*(1-1/p2)*(1-1/p3)...*(1-1/pk)来表示.(p为n的质因子) 求phi[p] ...
- bzoj 1500 修改区间 splay
内个我也不知道哪儿不对,TLE了,说说思路吧 其实思路也没什么说的,就是裸的splay,对于最后一个操作 我们记下每个区间的最长前缀,最长后缀,那么最长子序列就是 前缀,后缀,左子树的后缀+右子树的前 ...
- python3 内置函数(转)
http://www.runoob.com/python/python-built-in-functions.html divmod(7,2) # 返回(3,1)商和余的元组 frozenset() ...