思路:在该题中,如果游戏一开始处于平衡态,那么先取必败,输出lose; 如果游戏一开始处于非平衡态,那么先取必胜,剩下就是考虑怎么取了
就第一个样例而言,3^6^9的结果是12,12^3=15(3不能变到15),12^6=10(6不能变到10),12^9=5(9-4=5)
这是从样例中猜出来的判别方法
仔细一想确实这个样子,12^9是除了第3堆所有堆火柴的异或和,记为y,设新第3堆的值为z,要使状态达到平衡态,即y^z=0(y=z)
也就是说第三堆要变成y,接下来就判断是否能通过取火柴变到y。要按照堆号的字典序,直接按照堆号从小到大遍历即可
(战战兢兢地开了博弈论,自己A了真爽,希望能在重大时刻能遇到这样的水题┭┮﹏┭┮)
#include<iostream>
#include<algorithm>
using namespace std;
typedef long long LL;
const int N=5e5+