--- title: Codeforce 1383 B. GameGame 解析(思維、博弈) description: "Codeforce 1383 B. GameGame 解析(思維、博弈)" disqus: hackmd --- <meta name="robots" content="Codeforce 1383 B. GameGame 解析(思維、博弈)"> <!-- toc --> # Codeforce 1383 B. GameGame 解析(思維、博弈) 今天我們來看看CF1383B [題目連結](https://codeforces.com/problemset/problem/1383/B) > **題目** 兩個人在玩遊戲,有一個長度為$n$的數列$a$,每次每個人選一個數字和目前自己的分數XOR(初始為0分),最後拿到最多分數的人贏,求誰會贏? ### 前言 博弈的題目一直不是很會做,這次這題有個我平時可能不會想到的新想法:可以嘗試讓其中一個玩家跟隨另一個玩家做動作,如果被跟隨的那個玩家最後會輸,那麼跟隨的那個玩家就會贏。這是因為我們給出了一個明確的移動方法。 <div class="VVVcopyrightAAA";>@copyright petjelinux 版權所有<br> <a href="https://www.cnblogs.com/petjelinux/">觀看更多正版原始文章請至petjelinux的blog</a></div> ### 想法 首先要知道一件事:如果一個玩家能夠使得分數有最高位的bit,並且另外一個人沒有,那麼就贏了。這是因為在右邊的bit不管有多少,都比不上最左邊的bit(正式來說:$2^n>\sum\limits_{i=0}^{n-1}2^i\ \forall n\in\mathbb{N}_{\ge1}$)。 那麼我們可以先統計對於bit有幾個元素有這個bit,接著我們從最左邊的bit開始「考慮」: 分為兩種情況: 1. 這個bit有偶數個,那麼由於兩個玩家只有2種拿的方法 * 偶偶 * 奇奇 不管玩家怎麼拿,這個bit最後的狀態都是一樣的,所以我們可以完全不用考慮這個bit。 2. 這個bit有奇數個,也就是玩家要去搶這個bit: 首先另$x=$有這個bit的元素的數量,$y=n-x$也就是剩下的數字的數量(這個bit是$0$)。由於玩家們拿了$4$個$1$等同於沒有改變狀態,因此有以下的分類: 1. $x\mod 4=1$ and $y\mod 2=0$: 先手先拿一個$1$,接著完全照搬後手的行動。如此易發現先手會贏。 2. $x\mod 4=1$ and $y\mod 2=1$: 先手先拿一個$1$,接著完全照搬後手的行動,直到後手拿走了最後一個$0$,那麼接著就剩下要拿偶數個$1$,並且是先手先拿。由於是$x\mod 4=1$,所以最後是先手贏。 3. $x\mod 4=3$ and $y\mod 2=0$: 後手完全照搬先手的行動,最後先手一定會拿到偶數個$1$,所以後手贏。 4. $x\mod 4=3$ and $y\mod 2=1$: 先手先拿一個$0$,那麼就是3.的情況了,先手贏。 ### 程式碼: ```cpp= const int _n=1e5+10; int t,n,a[_n],cnt[32]; main(void) {cin.tie(0);ios_base::sync_with_stdio(0); cin>>t;while(t--){ cin>>n;rep(i,0,n)cin>>a[i]; memset(cnt,0,sizeof cnt); rep(j,0,30)rep(i,0,n)cnt[j]+=((a[i]&(1<<j))?1:0); per(i,0,30){ if(cnt[i]%2==0)continue; int x=cnt[i],y=n-x; if(x%4==3 and y%2==0){cout<<"LOSE\n";goto A;} else {cout<<"WIN\n";goto A;} }cout<<"DRAW\n"; A:; } return 0; } ``` 標頭、模板請點Submission看 [Submission](https://codeforces.com/contest/1383/submission/90386752)