結果
| 問題 | No.3496 協力カード当て |
| コンテスト | |
| ユーザー |
tau1235
|
| 提出日時 | 2026-04-14 23:07:23 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
AC
|
| 実行時間 | 66 ms / 2,000 ms |
| コード長 | 3,075 bytes |
| 記録 | |
| コンパイル時間 | 3,103 ms |
| コンパイル使用メモリ | 346,628 KB |
| 実行使用メモリ | 30,320 KB |
| スコア | 110 |
| 平均クエリ数 | 42.75 |
| 最終ジャッジ日時 | 2026-04-14 23:54:19 |
| 合計ジャッジ時間 | 6,384 ms |
|
ジャッジサーバーID (参考情報) |
judge3_1 / judge2_1 |
| 純コード判定しない問題か言語 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 16 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
int main(){
int id,n,m;
cin>>id>>n>>m;
vector<int> c(n);
for (int i=0;i<n;i++) cin>>c[i];
sort(c.begin(),c.end());
auto ASK=[&](int x){cout<<"ASK "<<x<<endl;};
auto GUESS=[&](vector<int> ans){
assert((int)ans.size()==n);
cout<<"GUESS";
for (int i=0;i<n;i++) cout<<" "<<ans[i];
cout<<endl;
};
if (n<=m){
vector<int> have(m);
vector<int> cnt(m,-1);
int t=0;
int now=0;
int havecnt=0;
while (true){
string s;
cin>>s;
if (s=="END"){
int q;
cin>>q;
return 0;
}
else if (s=="WAIT"){}
else if (s=="TURN"){
if (t==0){
ASK(c[now++]);
if (now==n) t=1;
}
else if (t==1){
bool f=true;
for (int i=0;i<m;i++) if (cnt[i]==-1){
ASK(i+1);
f=false;
break;
}
if (f){
vector<int> ans;
for (int i=0;i<m;i++){
int l=cnt[i]-have[i];
while (l--) ans.push_back(i+1);
}
GUESS(ans);
}
}
}
else assert(0);
cin>>s;
if (s=="END"){
int q;
cin>>q;
return 0;
}
else if (s=="GUESSED"){
int id,ok;
cin>>id>>ok;
assert(ok);
}
else if (s=="COUNT"){
int x,k;
cin>>x>>k;
x--;
if (havecnt<2*n){
have[x]++;
havecnt++;
}
cnt[x]=k;
}
else assert(0);
}
}
else{
vector<int> own(m);
for (int i=0;i<n;i++) own[c[i]-1]++;
vector<int> have(m);
vector<int> cnt(m,-1);
int t=0;
int now=0;
int havecnt=0;
while (true){
string s;
cin>>s;
if (s=="END"){
int q;
cin>>q;
return 0;
}
else if (s=="WAIT"){}
else if (s=="TURN"){
if (t==0){
int c=own[now++];
if (c==0) ASK(m);
else ASK(c);
if (now==m-1) t=1;
}
else if (t==1){
bool f=true;
for (int i=0;i<m;i++) if (cnt[i]==-1){
ASK(i+1);
f=false;
break;
}
if (f){
vector<int> ans;
int c0=0;
for (int i=0;i<m-1;i++){
int l=cnt[i]-have[i];
c0+=have[i];
while (l--) ans.push_back(i+1);
}
{
int l=cnt[m-1]-(n*2-c0);
while (l--) ans.push_back(m);
}
GUESS(ans);
}
}
}
else assert(0);
cin>>s;
if (s=="END"){
int q;
cin>>q;
return 0;
}
else if (s=="GUESSED"){
int id,ok;
cin>>id>>ok;
assert(ok);
}
else if (s=="COUNT"){
int x,k;
cin>>x>>k;
if (havecnt<(m-1)*2){
if (x!=m) have[havecnt/2]+=x;
havecnt++;
}
x--;
cnt[x]=k;
}
else assert(0);
}
}
}
tau1235