挺有意思的一道题。初探博弈论。

最好自己思考?

我们先考虑只有1轮游戏的情况。

这题明显要在字符串上一位一位地走,所以对字符串建立起trie。

最终建立起的trie的叶节点就是必败位置了。

对于非叶节点,如果它有一个儿子是必败节点,那么这个节点就是必胜节点了。(类似与mex函数)

那么如果根节点必胜,那么就是先手必胜,否则就是后手必胜了。

如果最后一轮后手必胜,那么两个人就需要争夺最后一轮的后手,所以他们要赢倒数第二轮。

而倒数第二轮和最后一轮是一样的,那么倒数第二轮也是后手必胜。倒数第二轮的后手整场游戏也必胜。

以此类推到倒数第三轮,倒数第四轮。。。直到第一轮,都一样。

所以,如果某一轮中后手必胜,那么整场游戏后手Dirty必胜。

剩下的情况就是先手必胜,那么就是要争夺先手,那么就要尽量输掉倒数第二轮。

如何判定先手能否必定让自己输掉一轮游戏?

只要把trie树的叶节点改为必胜节点就好了,再跑一遍。

那么如果先手可以必定让自己输掉一轮游戏,也能必定让自己赢一轮游戏。

那么除了最后一轮以外他都可以让自己输掉以取得先手,直到最后一轮让自己取胜。

所以,如果某一轮中先手必胜,先手在相反游戏中也必胜(即可以让自己必定输掉),那么整场游戏先手Pure必胜。

剩下的就是先手在一轮游戏中必胜,但是不能在相反游戏中取胜(即自己不能必定输掉)。

最后一轮是先手必胜。

倒数第二轮中要争夺最后一轮的先手,故要输掉,所以倒数第二轮中的后手在整场游戏中必胜。

倒数第三轮中要争夺倒数第二轮的后手,要赢,所以倒数第三轮的先手在整场游戏中必胜。

以此类推。。。

所以,如果一轮游戏先手必胜,而相反游戏后手必胜(即先手不能让自己输掉),总轮数为奇数时,先手Pure必胜。否则,后手Dirty必胜。

好题。

自己思考酣畅淋漓(数学自习灵感++)

 #include<cstdio>
#include<cstring>
using namespace std;
int k,trie[][],w[][],cnt,n,rt,len;char s[];
void insert(int &p,int al){
if(!p)p=++cnt;if(al==len)return;
insert(trie[p][s[al]-'a'],al+);
}
void dfs(int p){
int hs=;w[][p]=w[][p]=;
for(int i=;i<=;++i)if(trie[p][i]){hs=;break;}
if(!hs){w[][p]=;w[][p]=;return;}
for(int i=;i<=;++i)if(trie[p][i]){
dfs(trie[p][i]);
if(!w[][trie[p][i]])w[][p]=;
if(!w[][trie[p][i]])w[][p]=;
}
}
int main(){
int t;scanf("%d",&t);
while(t--){
scanf("%d%d",&n,&k);rt=cnt=;memset(trie,,sizeof trie);
for(int i=;i<=n;++i)scanf("%s",s),len=strlen(s),insert(rt,);
dfs(rt);//for(int i=1;i<=cnt;++i)printf("%d %d\n",w[0][i],w[1][i]);
if(!w[][rt])puts("Dirty");
else if(w[][rt])puts("Pure");
else if(k&)puts("Pure");
else puts("Dirty");
}
}

strGame:博弈论,trie的更多相关文章

  1. 20181228 模拟赛 T3 字符串游戏 strGame 博弈论 字符串

    3  字符串游戏(strGame.c/cpp/pas) 3.1  题目描述 pure 和 dirty 决定玩 T 局游戏.对于每一局游戏,有n个字符串,并且每一局游戏由K轮组成.具体规则如下:在每一轮 ...

  2. [杂题]:staGame(博弈论+Trie树+DFS)

    题目描述 $pure$和$dirty$决定玩$T$局游戏.对于每一局游戏,有$n$个字符串,并且每一局游戏由$K$轮组成.具体规则如下:在每一轮游戏中,最开始有一个空串,两者轮流向串的末尾添加一个字符 ...

  3. SPOJ COT3.Combat on a tree(博弈论 Trie合并)

    题目链接 \(Description\) 给定一棵\(n\)个点的树,每个点是黑色或白色.两个人轮流操作,每次可以选一个白色的点,将它到根节点路径上的所有点染黑.不能操作的人输,求先手是否能赢.如果能 ...

  4. SPOJ11414 COT3 博弈论 + Trie树合并

    考虑对于每个子树从下往上依次考虑 对于叶子节点而言,如果可以染色,那么其\(sg\)值为\(1\),否则为\(0\) 考虑往上合并 如果选择了\(x\),那么后继状态就是其所有子树 如果选了其他子树中 ...

  5. HY 的惩罚 (Trie 树,博弈论)

    [问题描述] hy 抄题解又被老师抓住了,现在老师把他叫到了办公室. 老师要 hy 和他玩一个游 戏.如果 hy 输了,老师就要把他开除信息组; 游戏分为 k 轮.在游戏开始之前,老师会将 n 个由英 ...

  6. CodeForces 455B A Lot of Games (博弈论)

    A Lot of Games 题目链接: http://acm.hust.edu.cn/vjudge/contest/121334#problem/J Description Andrew, Fedo ...

  7. 【10.4校内测试】【轮廓线DP】【中国剩余定理】【Trie树+博弈】

    考场上几乎是一看就看出来轮廓线叻...可是调了两个小时打死也过不了手出样例!std发下来一对,特判对的啊,转移对的啊,$dp$数组竟然没有取max!!! 某位考生当场死亡. 结果下午又请了诸位dala ...

  8. 【基础操作】博弈论 / SG 函数详解

    博弈死我了……(话说哪个小学生会玩博弈论提到的这类弱智游戏,还取石子) 先推荐两个文章链接:浅谈算法——博弈论(从零开始的博弈论) 博弈论相关知识及其应用 This article was updat ...

  9. 数据结构 | 30行代码,手把手带你实现Trie树

    本文始发于个人公众号:TechFlow,原创不易,求个关注 今天是算法和数据结构专题的第28篇文章,我们一起来聊聊一个经典的字符串处理数据结构--Trie. 在之前的4篇文章当中我们介绍了关于博弈论的 ...

随机推荐

  1. [WP8.1]RSA 使用BouncyCastle 公钥解密

    写应用的时候遇到个服务器返回私钥加密过的数据 ,然后要在客户端用公钥解密的需求 ,一直没找到方法,应用搁置了一个学期,多方搜索,结论就是.net没有实现公钥解密的方法,要自己实现,于是硬着头皮开始看  ...

  2. 痞子衡嵌入式:飞思卡尔i.MX RTyyyy系列MCU硬件那些事(2.1)- 玩转板载OpenSDA,Freelink调试器

    大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是飞思卡尔i.MX RTyyyy系列EVK上板载调试器的用法. 本文是i.MXRT硬件那些事系列第二篇,第一篇痞子衡给大家整体介绍了i.M ...

  3. C# 常见面试问题汇总

    1.c#垃圾回收机制 从以下方面入手展开:  1.压缩合并算法   2.代的机制  3.GC调用终结器 Garbage Collector . NET采用了和Java类似的方法由CLR(Common ...

  4. 全球首个开放应用模型 OAM 开源 | 云原生生态周报 Vol. 23

    作者 | 临石.元毅.冬岛.衷源.天元 业界要闻 全球首个开放应用模型 OAM 开源 2019 年 10 月 17 日,阿里巴巴合伙人.阿里云智能基础产品事业部总经理蒋江伟(花名:小邪)在 Qcon ...

  5. MFC下使用Mysql

    MFC工程需要使用Mysql数据库中遇到的问题记录下. 1.首先去官网下载下Mysql安装包,安装下Mysql. 我在这边下载的是mysql-installer-community-5.7.16.0. ...

  6. Cocos2d-x入门之旅[3]动作

    Cocos通过动作(Action)可以让精灵动起来,把数个动作组成序列(Sequence)就能让精灵做出连续的动作,在动作中我们可以改变精灵的位置,旋转角度,缩放比例,等等 动作(Action) 首先 ...

  7. redis安装及启动

    Redis 的安装及启动停止 下载 https://redis.io/download 软件copy至虚拟机中,常用的路径为/root/software 开始安装 安装gcc 目的是为了编译软件 yu ...

  8. Web安全 --Wfuzz 使用大全

    前言:  做web渗透大多数时候bp来fuzz   偶尔会有觉得要求达不到的时候 wfuzz就很有用了这时候 用了很久了这点来整理一次 wfuzz 是一款Python开发的Web安全模糊测试工具. 下 ...

  9. 渗透测试-基于白名单执行payload--Pcalua

    0x01 Pcalua简介 Windows进程兼容性助理(Program Compatibility Assistant)的一个组件. 说明:Pcalua.exe所在路径已被系统添加PATH环境变量中 ...

  10. [NOIp2017] luogu P3952 时间复杂度

    跪着看评测很优秀. 题目描述 给你若干个程序,这些程序只有 For 循环,求这些程序的时间复杂度. Solution 大模拟.讲下细节. flag[i]flag[i]flag[i] 表示第 iii 位 ...