結果
| 問題 | No.715 集合と二人ゲーム |
| コンテスト | |
| ユーザー |
ytft
|
| 提出日時 | 2021-04-07 00:06:13 |
| 言語 | C++14 (gcc 13.3.0 + boost 1.89.0) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 814 bytes |
| 記録 | |
| コンパイル時間 | 1,667 ms |
| コンパイル使用メモリ | 173,624 KB |
| 実行使用メモリ | 7,296 KB |
| 最終ジャッジ日時 | 2024-06-12 00:19:33 |
| 合計ジャッジ時間 | 7,572 ms |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 36 WA * 24 |
ソースコード
#include <bits/stdc++.h>
using namespace std;
int main(){
int N;
cin>>N;
vector<int> a(N);
for(int i=0;i<N;i++){
cin>>a[i];
}
sort(a.begin(),a.end());
vector<int> b;
int temp=1;
for(int i=1;i<N;i++){
if(a[i-1]+1<a[i]){
b.push_back(temp);
temp=1;
}else if(a[i-1]+1==a[i]){
temp++;
}
}
b.push_back(temp);
vector<int> grundy(500001,0);
grundy[1]=1;
grundy[2]=1;
for(int i=3;i<500001;i++){
if(grundy[i-3]+grundy[i-2]==1){
grundy[i]=2;
}else if(grundy[i-3]*grundy[i-2]==0){
grundy[i]=1;
}else{
grundy[i]=0;
}
}
int ans=0;
for(int i:b){
ans=ans^grundy[i];
}
cout<<(ans?"First":"Second")<<endl;
}
ytft