Submission #387166

#TimeUsernameProblemLanguageResultExecution timeMemory
387166kevinxiehkXoractive (IZhO19_xoractive)C++17
100 / 100
4 ms512 KiB
#include "interactive.h" #include "bits/stdc++.h" using namespace std; vector<int> guess(int n) { vector<int> ans(n); ans[0] = ask(1); vector<int> hm[7]; vector<int> hv[7]; set<int> tot; for(int i = 0; i <= floor(log2(n)); i++) { if(n < (1 << i)) break; for(int j = 2; j <= n; j++) { if(j & (1 << i)) hm[i].push_back(j); } vector<int> have = get_pairwise_xor(hm[i]); hm[i].push_back(1); vector<int> have2 = get_pairwise_xor(hm[i]); int add = 1; have.push_back(-1); have2.push_back(-1); for(int j = 0; j < have.size(); j++) { while(have[j] != have2[j + add]){ hv[i].push_back(have2[j + add] ^ ans[0]); tot.insert(have2[j + add] ^ ans[0]); add += 2; } } assert(hv[i].size() == hm[i].size() - 1); } for(auto x: tot) { int id = 0; for(int i = 0; i <= floor(log2(n)); i++) { for(auto y: hv[i]) { if(x == y) { id += (1 << i); } } } ans[id - 1] = x; } return ans; }

Compilation message (stderr)

Xoractive.cpp: In function 'std::vector<int> guess(int)':
Xoractive.cpp:22:20: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   22 |   for(int j = 0; j < have.size(); j++) {
      |                  ~~^~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...