Submission #384344

#TimeUsernameProblemLanguageResultExecution timeMemory
384344vanicXoractive (IZhO19_xoractive)C++14
0 / 100
3 ms620 KiB
#include "interactive.h" #include <cmath> #include <iostream> #include <algorithm> #include <set> #include <cassert> using namespace std; const int Log=7; vector < int > sol; vector < int > q; vector < int > odg1, odg2; vector < int > komp; vector < int > val[Log]; vector < int > tren; void probaj(int x){ int pos; for(int i=0; i<Log; i++){ if((1<<i)&x){ if(tren.empty()){ tren=val[i]; } else{ pos=0; for(int j=0; j<(int)tren.size(); j++){ while(pos<(int)val[i].size() && val[i][pos]<tren[j]){ pos++; } if(pos>=(int)val[i].size() || tren[j]!=pos){ tren.erase(tren.begin()+j); j--; } else{ pos++; } } } } } assert(tren.size()==1); for(int i=0; i<Log; i++){ if((1<<i)&x){ val[i].erase(find(val[i].begin(), val[i].end(), tren[0])); } } sol[x]=tren[0]; tren.clear(); } vector < int > guess(int n){ sol.resize(n, 0); sol[0]=ask(1); for(int j=0; j<Log; j++){ for(int i=1; i<n; i++){ if(i&(1<<j)){ q.push_back(i+1); } } odg2=get_pairwise_xor(q); q.push_back(1); odg1=get_pairwise_xor(q); q.clear(); int pos1=0, pos2=0; for(int i=0; i<(int)odg1.size(); i++){ if(pos2<(int)odg2.size() && odg1[pos1]==odg2[pos2]){ pos1++; pos2++; } else{ komp.push_back(odg1[pos1]); pos1++; } } komp.erase(komp.begin()); for(int i=0; i<n-1; i++){ val[j].push_back(sol[0]^komp[i]); } } for(int i=n-1; i>0; i--){ probaj(i); } return sol; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...