Solution
令
bi=ai−ai−1
。那么原题意就是相当与每次从一堆石子中取出
x
个,然后在右边的一堆加上
这就是一个阶梯博弈的模型。
只需要考虑奇数位的
NIM
游戏就好了。
因为偶数位可以根据对手的行动保证必胜。
#include <bits/stdc++.h>
using namespace std;
const int N = 101010;
int n, SG, test;
int a[N];
int main(void) {
freopen("1.in", "r", stdin);
freopen("1.out", "w", stdout);
scanf("%d", &test);
while (test--) {
scanf("%d", &n); SG = 0;
for (int i = 1; i <= n; i++) scanf("%d", &a[i]);
for (int i = n; i > 0; i -= 2) SG ^= (a[i] - a[i - 1]);
if (SG) puts("TAK");
else puts("NIE");
}
return 0;
}