--- title: Codeforce 839 B. Game of the Rows 解析(思維) description: "Codeforce 839 B. Game of the Rows 解析(思維)" disqus: hackmd --- <meta name="robots" content="Codeforce 839 B. Game of the Rows 解析(思維)"> <!-- toc --> # Codeforce 839 B. Game of the Rows 解析(思維) 今天我們來看看CF839B [題目連結](https://codeforces.com/problemset/problem/839/B) > **題目** 有如下圖片所示的飛機座位$n$排,和$k$隊士兵,每隊數量不一定。 ![](https://i.imgur.com/1vMRL5j.png) 求是否可以每隊都坐上去並且沒有任何兩個士兵相鄰「並且」是不同隊的。 ### 前言 思考時小心一點,記得座位有很多種捨棄方法 ### 想法 注意到,在座位足夠的情況下,我們可以有三步驟的方法來捨去座位。 1. 把中間的$4$個座位分成$1,2$人座位 (此步把可以得到的間隔都得到了) 2. 把左右的2個2人座位隨便選一個(或者兩個都選)捨去一個座位,變成$1$人座位 3. 把中間已經拆成$1,2$人座位的4個座位,再捨去一個,變成$1,1$人座位 ($2.3.$兩個步驟是在把$2$人座位換成$1$人座位,這樣才能方便等等的分配座位順利運行) 接著要把士兵一隊一隊分配進去。現在已經有$1,2,4$人座位的數量了,而這些座位都是分開的,那麼我們只要從最大的座位開始把士兵分配進去就好。 ### 程式碼: ```cpp= const int _n=1e4+10; int t,tt,ttt,n,k,a[_n],sum=0,cnt[5]; main(void) {cin.tie(0);ios_base::sync_with_stdio(0); cin>>n>>k;rep(i,0,k){cin>>a[i];sum+=a[i];} cnt[2]=2*n,cnt[4]=n; t=min(n,8*n-sum); cnt[1]=t,cnt[2]+=t,cnt[4]-=t; if(t==n){tt=min(2*n,8*n-n-sum); cnt[1]+=tt,cnt[2]-=tt;} if(tt==2*n){ttt=min(n,8*n-n-n-n-sum); cnt[1]+=ttt,cnt[2]-=ttt;} rep(i,0,k){ int f=min(cnt[4],a[i]/4); cnt[4]-=f; a[i]-=4*f; f=min(cnt[2],a[i]/2); cnt[2]-=f; a[i]-=2*f; f=min(cnt[1],a[i]); cnt[1]-=f; a[i]-=f; if(a[i]){cout<<"NO\n";return 0;} }cout<<"YES\n"; return 0; } ``` 標頭、模板請點Submission看 [Submission](https://codeforces.com/contest/839/submission/90458994)