CodeForces 455B A Lot of Games (博弈论)
A Lot of Games
题目链接:
http://acm.hust.edu.cn/vjudge/contest/121334#problem/J
Description
Andrew, Fedor and Alex are inventive guys. Now they invent the game with strings for two players.
Given a group of n non-empty strings. During the game two players build the word together, initially the word is empty. The players move in turns. On his step player must add a single letter in the end of the word, the resulting word must be prefix of at least one string from the group. A player loses if he cannot move.
Andrew and Alex decided to play this game k times. The player who is the loser of the i-th game makes the first move in the (i + 1)-th game. Guys decided that the winner of all games is the player who wins the last (k-th) game. Andrew and Alex already started the game. Fedor wants to know who wins the game if both players will play optimally. Help him.
Input
The first line contains two integers, n and k (1 ≤ n ≤ 105; 1 ≤ k ≤ 109).
Each of the next n lines contains a single non-empty string from the given group. The total length of all strings from the group doesn't exceed 105. Each string of the group consists only of lowercase English letters.
Output
If the player who moves first wins, print "First", otherwise print "Second" (without the quotes).
Sample Input
Input
2 3
a
b
Output
First
Input
3 1
a
b
c
Output
First
Input
1 2
ab
Output
Second
##题意:
给出n个字符串(总长度不超过10^5);
A B两人轮流进行如下操作:
1. 初始时目标串为空
2. 当前玩家在目标串末尾添加一个字符
3. 要求每次添加后的目标串是给出的任一字符串的前缀
4. 不能操作者输
(游戏共进行k轮,每轮输者在下一轮为先手)
##题解:
首先这是一个博弈论问题.
要求每次目标串都是给定串的前缀,很自然想到用字典树来建模.
这个游戏有一个特别的地方:本局的赢家在下局是后手. 这意味着玩家可能会选择输掉当前局来获取最后的胜利.
我们只用处理单局的情况:
1. 如果先手在单局中处于必输状态,那么他一定会输掉最后的比赛(一直输).
2. 如果先手在单局中有必胜的走法,那么他不一定会选择在所有情况下都赢.
1. 如果先手可以控制自己必输或必赢,那么他一定会赢得最后的比赛(一直输,最后一场选择胜利).
2. 如果先手只能赢无法输(比如只有一个字符),那么他的结果取决与k的奇偶性(奇胜偶败).
- 综上,只需要处理出单局中先手是必输/必胜/可输可赢,这里采用两次dfs来完成判断:
- 先搜索是否有必胜的走法(叶结点必输,可到必输的点为必胜,只能到必胜的点为必输).
- 再搜索是否有必败的走法(叶结点必输,可到必胜的点为必输,只能到必输的点为必胜).
##代码:
``` cpp
#include
#include
#include
#include
#include
#include
#include
#include
#include
#define LL long long
#define eps 1e-8
#define maxn 101000
#define mod 100000007
#define inf 0x3f3f3f3f
#define IN freopen("in.txt","r",stdin);
using namespace std;
struct Trie
{
bool isStr;
int next;
Trie(){isStr=false;next=-1;}
}trie[maxn][26];
int cnt;
void insert(char s)
{
int len=strlen(s),cur=0;
for(int i=0;i<len;i++)
{
if(trie[cur][s[i]-'a'].next==-1)
trie[cur][s[i]-'a'].next=++cnt; / from 1; 0 is root /
if(i==len-1)
trie[cur][s[i]-'a'].isStr=true;
cur=trie[cur][s[i]-'a'].next;
}
}
/以上为字典树模版*/
int n,m;
char str[maxn];
/*
1表示当前局面存在必胜走法; 0表示只有必败.
子节点中有0则1,全1则0.
*/
int dfs(int cur) {
int ans = 0;
int cnt = 0;
for(int i=0; i<26; i++) {
if(trie[cur][i].next != -1)
cnt+=1, ans += dfs(trie[cur][i].next);
}
if(cnt == ans) return 0;
else return 1;
}
/*
1表示当前局面存在必输走法; 0表示只有必赢.
子节点中有0则1,全1则0.
*/
int dfs2(int cur) {
int ans = 0;
int cnt = 0;
for(int i=0; i<26; i++) {
if(trie[cur][i].next != -1)
cnt+=1, ans += dfs2(trie[cur][i].next);
}
if(!cnt) return 1;
if(cnt == ans) return 0;
else return 1;
}
void init() {
for(int i=0; i<maxn; i++) {
for(int j=0; j<26; j++) {
trie[i][j].isStr = 0;
trie[i][j].next = -1;
}
}
}
int main(int argc, char const *argv[])
{
//IN;
while(scanf("%d %d", &n,&m) != EOF)
{
init();
while(n--) {
scanf("%s", str);
insert(str);
}
int ans1 = dfs(0);
if(!ans1) {
puts("Second"); continue;
}
int ans2 = dfs2(0);
if(!ans2) {
if(m&1) puts("First");
else puts("Second");
} else {
puts("First");
}
}
return 0;
}
CodeForces 455B A Lot of Games (博弈论)的更多相关文章
- Codeforces 455B A Lot of Games(字典树+博弈)
题目连接: Codeforces 455B A Lot of Games 题目大意:给定n.表示字符串集合. 给定k,表示进行了k次游戏,然后是n个字符串.每局開始.字符串为空串,然后两人轮流在末尾追 ...
- Codeforces 455B A Lot of Games
http://codeforces.com/contest/455/problem/B 题目大意: 给出n个字符串,进行k次游戏,每次游戏输家下次作为先手,游戏规则为每次放一个字母,导致当前构造的字符 ...
- Codeforces 455B A Lot of Games:博弈dp【多局游戏】
题目链接:http://codeforces.com/problemset/problem/455/B 题意: 给你n个字符串,然后进行k局游戏. 每局游戏开始有一个空串,然后双方轮流给这个串的末尾添 ...
- codeforces 455B A Lot of Games(博弈,字典树)
题目 参考自博客:http://blog.csdn.net/keshuai19940722/article/details/38455269 //字典树,博弈 根据当前节点的后续来确定当前节点的状态, ...
- Codeforces 455B A Lot of Games 字典树上博弈
题目链接:点击打开链接 题意: 给定n个字符串,k局游戏 对于每局游戏,2个玩家轮流给一个空串加入一个小写字母使得加完后的字符串不是n个字符串的前缀. 输家下一轮先手 问是先手必胜还是后手必胜 思路: ...
- [codeforces 325]B. Stadium and Games
[codeforces 325]B. Stadium and Games 试题描述 Daniel is organizing a football tournament. He has come up ...
- Codeforces 980 E. The Number Games
\(>Codeforces \space 980 E. The Number Games<\) 题目大意 : 有一棵点数为 \(n\) 的数,第 \(i\) 个点的点权是 \(2^i\) ...
- codeforces 1451D,一道有趣的博弈论问题
大家好,欢迎来到codeforces专题. 今天选择的问题是Contest 1451场的D题,这是一道有趣简单的伪博弈论问题,全场通过的人有3203人.难度不太高,依旧以思维为主,坑不多,非常友好. ...
- 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 ...
随机推荐
- Chosen中选择项的更新
Chosen 选择项的动态修改/更新 如果你需要去动态更新select选择框里的选择项,你需要通知Chosen去响应这个变动,你需要在这个选项框是触发一个"liszt:updated&quo ...
- 函数xdes_init
/**********************************************************************//** Inits an extent descript ...
- Ajax的“dataType”乱用的陷阱
$.doAjax({ url : "areaAction_synchronizeArea.do", data : { 'vrvRangeUrl' : synAreaHTTP ,'v ...
- web交互方式
轮询:客户端定时向服务器发送Ajax请求,服务器接到请求后马上返回响应信息并关闭连接. 优点:后端程序编写比较容易. 缺点:请求中有大半是无用,浪费带宽和服务器资源. 实例:适于小型应用. 长轮询:客 ...
- Ubuntu解决Sublime Text 2安装GBK Encoding Support插件仍然乱码
Ubuntu 12.04 32位下,为Sublime Text 2安装Package Control: 1. 用Ctrl+~打开控制台,输入 import urllib2,os; pf='Packag ...
- ionic preparing for ios 9
http://blog.ionic.io/preparing-for-ios-9/ Preparing for iOS 9 Tweet By Max on September 12, 2015 i ...
- Linux中 干掉原来的PHP方法
干掉原来的PHP方法: 查看php版本命令:#php -v这个命令是删除不干净的#yum remove php因为使用这个命令以后再用#php -v还是会看到有版本信息的..... 必须强制删除#rp ...
- 如何寻找设计灵感?写给刚入行的设计师(转自UI中国)
如何寻找设计灵感?写给刚入行的设计师 如何寻找设计灵感? 这一次的文章,我想和大家聊聊年轻的设计师在没有那么多经验的情况下如何寻找设计师灵感.(希望这篇文章也能帮助感同身受的你) 每个设计师对设计都有 ...
- 如何解决重启数据库时报ORA-01031无法登数据库
问题现象:以无用户方式登录数据库,重启或关闭数据时,遇到下列问题: C:\Documents and Settings\xuzhengzhu>sqlplus /nolog SQL*Plus: R ...
- 从网页监听Android设备的返回键
最近搞Android项目的时候,遇到一个比较蛋疼的需求,需要从Client App调用系统浏览器打开一个页面,进行杂七杂八的一些交互之后,返回到App.如何打开浏览器和如何返回App这里就不说了,有兴 ...