結果
| 問題 | No.3496 協力カード当て |
| コンテスト | |
| ユーザー |
tau1235
|
| 提出日時 | 2026-04-14 22:18:15 |
| 言語 | C++23 (gcc 15.2.0 + boost 1.89.0) |
| 結果 |
TLE
|
| 実行時間 | - |
| コード長 | 1,238 bytes |
| 記録 | |
| コンパイル時間 | 2,848 ms |
| コンパイル使用メモリ | 343,404 KB |
| 実行使用メモリ | 39,872 KB |
| スコア | 6 |
| 平均クエリ数 | 1.56 |
| 最終ジャッジ日時 | 2026-04-14 23:52:09 |
| 合計ジャッジ時間 | 9,642 ms |
|
ジャッジサーバーID (参考情報) |
judge1_0 / judge2_0 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 1 TLE * 1 -- * 14 |
ソースコード
#include<bits/stdc++.h>
using namespace std;
int main(){
int id,n,m;
cin>>id>>n>>m;
id--;
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") return 0;
if (s=="WAIT"){}
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;
}
}
}
cin>>s;
if (s=="GUESSED"){
int id,ok;
cin>>id>>ok;
assert(ok);
}
if (s=="COUNT"){
int x,k;
cin>>x>>k;
x--;
if (havecnt<2*n){
have[x]++;
havecnt++;
}
cnt[x]=k;
}
}
}
tau1235