AGC 010D.Decrementing(博弈)
\(Description\)
给定\(n\)个数\(A_i\),且这\(n\)个数的\(GCD\)为\(1\)。两个人轮流进行如下操作:
- 选择一个\(>1\)的数使它\(-1\)。
- 第一步进行完后,所有数会变成它除以\(g\),其中\(g\)是\(n\)个数的\(GCD\)。
当轮到一个人操作,但所有数为\(1\)时,该人输。求先手是否必胜。
\(n\leq10^5,\ A_i\leq10^9\)。
\(Solution\)
首先能发现一些性质:
- 当有一个数变成\(1\)时,答案只和所有数的和\(-n\)的奇偶性有关。
- 对所有数除以一个奇数,任意一个数的奇偶性不变;除以一个偶数,奇偶性不确定。
- \(g\neq1\)时,除以\(g\)的操作不会进行超过\(30\)次。
考虑先手。
假设当前\(\sum(A_i-1)\)的奇偶性为奇数,即处于优势,那么他应该保持操作完(所有数除以\(g\)后)所有数的奇偶性还是偶数。
注意到当有至少一个奇数时,\(GCD\)不可能为偶数。而最初所有数的\(GCD\)为\(1\),那么至少有一个奇数。另外此时偶数有奇数个,如果任意修改一个偶数,\(g\)一定还是奇数。
考虑现在的后手。先手进行上述操作后存在至少两个奇数,所以一定不能使\(g\)变为偶数来改变局面。而先手可以保持奇数的个数一直增加,所以后手没法翻盘,必败。
如果当前\(\sum(A_i-1)\)的奇偶性为偶数,即处于劣势,那么先手要使操作后的\(g\)变为偶数才可能翻盘。
由上面的分析,如果存在\(>1\)个的奇数,先手必败。否则先手只能修改这个奇数让\(g\)变成偶数。但是现在仍不能判断胜负,继续递归下一层。
最多递归\(\log\)层,所以复杂度\(O(n\log A)\)。(似乎还有个求\(\gcd\)...)
//32ms 896KB
#include <cstdio>
#include <cctype>
#include <algorithm>
#define gc() getchar()
#define MAXIN 300000
//#define gc() (SS==TT&&(TT=(SS=IN)+fread(IN,1,MAXIN,stdin),SS==TT)?EOF:*SS++)
typedef long long LL;
const int N=1e5+5;
int n,A[N];
char IN[MAXIN],*SS=IN,*TT=IN;
inline int read()
{
int now=0;register char c=gc();
for(;!isdigit(c);c=gc());
for(;isdigit(c);now=now*10+c-48,c=gc());
return now;
}
bool DFS(bool now)
{
int s=0,fg=0;
for(int i=1; i<=n; ++i) A[i]==1&&(fg=1), s+=A[i]&1;
if((n-s)&1) return now;
if(fg||s>1) return now^1;
for(int i=1; i<=n; ++i)
if(A[i]&1) {--A[i]; break;}
int g=A[1];
for(int i=2; i<=n; ++i) g=std::__gcd(g,A[i]);
for(int i=1; i<=n; ++i) A[i]/=g;
return DFS(now^1);
}
int main()
{
const int n=read(); ::n=n;
for(int i=1; i<=n; ++i) A[i]=read();
puts(DFS(1)?"First":"Second");
return 0;
}
AGC 010D.Decrementing(博弈)的更多相关文章
- RE:从零开始的AGC被虐(到)生活(不能自理)
RE:从零开始的AGC被虐(到)生活(不能自理) 「一直注视着你,似近似远,总是触碰不到.」 --来自风平浪静的明天 AtCoder Grand Contest 001 B: Mysterious L ...
- [AtCoderContest010D]Decrementing
[AtCoderContest010D]Decrementing 试题描述 There are \(N\) integers written on a blackboard. The \(i\)-th ...
- hdu----(1849)Rabbit and Grass(简单的尼姆博弈)
Rabbit and Grass Time Limit: 1000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others) ...
- HDU 5754 Life Winner Bo 组合博弈
Life Winner Bo Problem Description Bo is a "Life Winner".He likes playing chessboard gam ...
- HDU 2509 Nim博弈变形
1.HDU 2509 2.题意:n堆苹果,两个人轮流,每次从一堆中取连续的多个,至少取一个,最后取光者败. 3.总结:Nim博弈的变形,还是不知道怎么分析,,,,看了大牛的博客. 传送门 首先给出结 ...
- HDU 1907 Nim博弈变形
1.HDU 1907 2.题意:n堆糖,两人轮流,每次从任意一堆中至少取一个,最后取光者输. 3.总结:有点变形的Nim,还是不太明白,盗用一下学长的分析吧 传送门 分析:经典的Nim博弈的一点变形. ...
- 51nod1072(wythoff 博弈)
题目链接: http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1072 题意: 中文题诶~ 思路: 博弈套路是有的, 找np局 ...
- ACM: NBUT 1107 盒子游戏 - 简单博弈
NBUT 1107 盒子游戏 Time Limit:1000MS Memory Limit:65535KB 64bit IO Format: Practice Appoint ...
- 【转】ACM博弈知识汇总
博弈知识汇总 转自:http://www.cnblogs.com/kuangbin/archive/2011/08/28/2156426.html 有一种很有意思的游戏,就是有物体若干堆,可以是火柴棍 ...
随机推荐
- django----基于Form组件实现的增删改和基于ModelForm实现的增删改
一.ModelForm的介绍 ModelForm a. class Meta: model, # 对应Model的 fields=None, # 字段 exclude=None, # 排除字段 lab ...
- poj2942 求v-DCC,二分图判奇环,补图
/* 给定一张无向图,求有多少点不被任何奇环包含 推论1:如果两个点属于两个不同的v-DCC,则他们不可能在同一个奇环内 推论2:某个v-DCC中有奇环,则这个v-DCC中所有点必定被属于某个奇环 只 ...
- sublime快捷键的使用
Sublime text 3是码农最喜欢的代码编辑器,每天和代码打交道,必先利其器,掌握基本的代码编辑器的快捷键,能让你打码更有效率.刚开始可能有些生疏,只要花一两个星期坚持使用并熟悉这些常用的快捷键 ...
- redis监控脚本
while [ 1 == 1 ] ; do now=$(date "+%Y-%m-%d_%H:%M:%S") ; echo "================== ...
- MySQL 命令总结
MySQL命令总结 1.数据库操作 查看在当前服务器中有多少个数据库 创建数据库 >CREATE DATABASE db_name DEFAULT CHARACTER SET utf8 COLL ...
- php 连接redis服务器
$redis = new Redis(); //实例化 $redis->connect("local ...
- P1441 砝码称重 DFS回溯+DP
题目描述 现有n个砝码,重量分别为a1,a2,a3,……,an,在去掉m个砝码后,问最多能称量出多少不同的重量(不包括0). 请注意,砝码只能放在其中一边. 输入输出格式 输入格式: 输入文件weig ...
- Hadoop |集群的搭建
Hadoop组成 HDFS(Hadoop Distributed File System)架构概述 NameNode目录--主刀医生(nn): DataNode(dn)数据: Secondary N ...
- 052 kafka对topic的增删改查操作
一:create 1.开始使用命令 2.创建 bin/kafka-topics.sh --create --topic beifeng --zookeeper linux-hadoop01.ibeif ...
- Ubuntu 硬盘分区只读,重新挂载为读写分区之后,文件依然创建出错
原因: 分区只读,可能是windows没有正常关机,或者使用了混合休眠模式. 解决方案: sudo mount -o remount,rw /dev/sdaX 若重新挂载后,创建文件以及文件夹失败: ...