CYJian
2020-03-22 08:41:30
赛时做法:
手玩样例 + 合理推理之后,不难发现,
那么问题来了:怎么判断是谁呢?
冷静分析之后,我们发现,如果不直接计算出最后是谁,而是排除最后一定不是谁,就能从另一个角度知道结果了。
然后再想想,如果
然后这时候我们就只需要判定答案是
不难发现,模
不难发现是类似组合数递推的,只不过转移方向反过来而已。利用组合数可以得到:
利用 Lucas
定理,就能
当然,对于
然后再考虑没有
char s[1000010];
inline int C(int n, int m) { return (n & m) == m; }
int main() {
int n;
scanf("%d%s", &n, s + 1);
if(n == 1) putchar(s[1]), puts("");
else {
--n;
int find1 = 0;
for(int j = 1; j <= n; j++)
s[j] = abs(s[j] - s[j + 1]), find1 |= s[j] == 1;
if(!find1) for(int i = 1; i <= n; i++) s[i] >>= 1;
find1 ^= 1;
int t = 0;
for(int j = 1; j <= n; j++) t ^= C(n - 1, j - 1) * (s[j] & 1);
cout << (int(t) << find1) << endl;
}
return 0;
}