結果
| 問題 | No.3496 協力カード当て |
| コンテスト | |
| ユーザー |
tau1235
|
| 提出日時 | 2026-04-14 22:33:29 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
QLE
|
| 実行時間 | - |
| コード長 | 1,398 bytes |
| 記録 | |
| コンパイル時間 | 2,203 ms |
| コンパイル使用メモリ | 343,300 KB |
| 実行使用メモリ | 30,076 KB |
| スコア | 81 |
| 平均クエリ数 | 45.81 |
| 最終ジャッジ日時 | 2026-04-14 23:52:30 |
| 合計ジャッジ時間 | 5,033 ms |
|
ジャッジサーバーID (参考情報) |
judge1_1 / judge3_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 13 QLE * 3 |
ソースコード
#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());
vector<int> have(m);
vector<int> cnt(m,-1);
int t=0;
int now=0;
int havecnt=0;
auto ASK=[&](int x){cout<<"ASK "<<x<<endl;};
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);
}
assert((int)ans.size()==n);
cout<<"GUESS";
for (int i=0;i<n;i++) cout<<" "<<ans[i];
cout<<endl;
}
}
}
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);
}
}
tau1235