Submission #1075067

#TimeUsernameProblemLanguageResultExecution timeMemory
1075067pawnedCOVID tests (CEOI24_covid)C++17
52.27 / 100
1864 ms596 KiB
#pragma GCC optimize("O1,O2,O3,Ofast,unroll-loops") #include <bits/stdc++.h> using namespace std; #define fi first #define se second #define pb push_back typedef long long ll; typedef pair<int, int> ii; typedef vector<int> vi; const char nl = '\n'; void fastIO() { ios::sync_with_stdio(false); cin.tie(0); } int N, T; double P; char query(vi v) { string s(N, '0'); for (int x : v) s[x] = '1'; cout<<"Q "<<s<<endl; cout.flush(); char c; cin>>c; return c; } char query(int l, int r) { string s(N, '0'); for (int i = l; i <= r; i++) { s[i] = '1'; } cout<<"Q "<<s<<endl; cout.flush(); char c; cin>>c; return c; } string ans(N, '0'); void solve(int left, int right) { // know there's positive on range if (left == right) { ans[left] = '1'; return; } int mid = (left + right) / 2; if (query(left, mid) == 'P') { solve(left, mid); if (query(mid + 1, right) == 'P') solve(mid + 1, right); } else { // surely has in right solve(mid + 1, right); } } int main() { fastIO(); cin>>N>>P>>T; for (int i = 0; i < T; i++) { ans = string(N, '0'); if (query(0, N - 1) == 'P') solve(0, N - 1); // cout<<"ANSWER: "; cout<<"A "<<ans<<endl; cout.flush(); char c; cin>>c; if (c == 'W') break; } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...