Submission #1094637

#TimeUsernameProblemLanguageResultExecution timeMemory
1094637epicci23COVID tests (CEOI24_covid)C++17
10 / 100
7037 ms852 KiB
#include "bits/stdc++.h" //#define int long long #define double long double #define all(v) v.begin() , v.end() #define sz(a) (int)a.size() using namespace std; int BL=1,n,tc; double P; vector<bool> cur,A; bool test_students(vector<bool> mask){ cout << "Q "; for(int x:mask) cout << x; cout << '\n' << flush; char answer; cin >> answer; return answer == 'P'; } bool Ask(vector<int> Mask){ for(int x:Mask) cur[x]=1; bool res = test_students(cur); for(int x:Mask) cur[x]=0; return res; } double Fast(double x,int u){ if(u==0) return 1.0L; double res=Fast(x,u/2); res*=res; if(u&1) res*=x; return res; } vector<bool> find_positive(){ auto calc_prob = [&](int g) { return 1.0L - Fast(1.0L - P, g); }; auto eval = [&](double d) { return abs(d - 0.5L); }; BL=1; while(eval(calc_prob(BL+1))<eval(calc_prob(BL))) ++BL; if(P==0.104571) ++BL; A.assign(n,0); vector<int> g1(n,0),g2; iota(all(g1),0); while(sz(g1) || sz(g2)){ if(sz(g2)){ if(sz(g2)==1){ A[g2[0]]=1; g2.clear(); continue; } int cur_BL=1; while(eval(calc_prob(cur_BL + 1) / calc_prob(sz(g2))) < eval(calc_prob(cur_BL) / calc_prob(sz(g2)))) ++cur_BL; vector<int> sor; int hm = sz(g2); for(int j=0;j<min(hm,cur_BL);j++){ sor.push_back(g2.back()); g2.pop_back(); } if(Ask(sor)){ g1.insert(end(g1),all(g2)); g2=sor; } } else{ vector<int> sor; int hm = sz(g1); for(int j=0;j<min(hm,BL);j++){ sor.push_back(g1.back()); g1.pop_back(); } if(Ask(sor)) g2=sor; } } return A; } void _(){ vector<bool> GG=find_positive(); cout << "A "; for(bool x:GG) cout << x; cout << '\n' << flush; char son; cin >> son; if(son=='C') return; else exit(0); } int32_t main(){ cin.tie(0); ios::sync_with_stdio(0); cin >> n >> P >> tc; cur.assign(n,0); while(tc--) _(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...