标签:Piles 先手 int 奇数 Candy 偶数 必胜 方向
显然将 \(a\) 降序排序后,然后依次放到坐标系中,每次操作相当于把 \(x,y\) 轴之一往上或右平移一个单位
考虑构造一种后手必胜的方案
后手可以把路线控制在 \(y = x\) 上,然后走到一个端点,此时轮到先手
设还可以向上走 \(b\),向右走 \(c\)
若 \(b,c\) 均为偶数则后手必胜
考虑证明剩下的均为先手必胜
\(b,c\) 其中之一必为奇数,那么先手往奇数的方向走一个单位,那么另外的方向上的数就变为 \(0\),而该方向的长度减 \(1\) 变为偶数
可以发现变成了后手必胜的局面
#include <bits/stdc++.h>
using namespace std;
const int N = 1e5 + 10;
int n, a[N];
int main() {
scanf("%d", &n);
for (int i = 1; i <= n; i++)
scanf("%d", &a[i]);
sort(a + 1, a + n + 1);
reverse(a + 1, a + n + 1);
int x = 1, b = 0, c = 0;
while (x < n && a[x + 1] >= x + 1)
x++;
b = a[x] - x;
while (a[x + c + 1] == x)
c++;
printf("%s\n", (b|c)&1 ? "First" : "Second");
}
标签:Piles,先手,int,奇数,Candy,偶数,必胜,方向 来源: https://www.cnblogs.com/iqx37f/p/14455360.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。