Submission #290788

#TimeUsernameProblemLanguageResultExecution timeMemory
290788PlurmXoractive (IZhO19_xoractive)C++11
100 / 100
7 ms672 KiB
#include <bits/stdc++.h> #include "interactive.h" using namespace std; vector<int> multisetDifference(vector<int> a, vector<int> b){ sort(a.begin(), a.end()); multiset<int> msb(b.begin(), b.end()); vector<int> out; for(int x : a){ if(msb.find(x) == msb.end()){ out.push_back(x); }else{ msb.erase(msb.find(x)); } } return out; } vector<int> setDifference(vector<int> a, vector<int> b){ sort(a.begin(), a.end()); sort(b.begin(), b.end()); /* for(int i = 1; i < a.size(); i++) assert(a[i-1] <= a[i]); for(int i = 1; i < b.size(); i++) assert(b[i-1] <= b[i]); */ vector<int> out; for(int x : a){ if(!binary_search(b.begin(), b.end(), x)) out.push_back(x); } return out; } int front; int lb[256]; int rb[256]; vector<int> qdep[8]; vector<int> ansdep[8]; vector<int> seg[256]; void build(int c, int l, int r, int dep = 0){ lb[c] = l; rb[c] = r; qdep[dep].push_back(c); if(l == r) return; int k = (l+r)/2; build(2*c, l, k, dep+1); build(2*c+1, k+1, r, dep+1); } void propagate(int c, int dep = 0){ if(c == 1) seg[1] = ansdep[0]; else if(c % 2 == 0){ seg[c] = setDifference(seg[c/2], seg[c+1]); }else{ seg[c] = setDifference(seg[c/2], ansdep[dep]); } if(lb[c] == rb[c]) return; propagate(2*c+1, dep+1); propagate(2*c, dep+1); } void collect(int c, vector<int>& ans){ if(lb[c] == rb[c]){ if(!seg[c].empty()) ans.push_back(seg[c].front()); return; } collect(2*c, ans); collect(2*c+1, ans); } vector<int> guess(int n) { front = ask(1); build(1, 1, n+1); for(int i = 1; i < 8; i++){ if(qdep[i].empty()) break; vector<int> query; for(int x : qdep[i]){ if(x % 2 == 0 || x == 1){ for(int j = lb[x]; j <= rb[x] && j <= n; j++) query.push_back(j); } } if(query.empty()) break; assert(query.front() == 1); vector<int> i1 = get_pairwise_xor(query); query.erase(query.begin()); vector<int> i2 = query.empty() ? vector<int>() : get_pairwise_xor(query); vector<int> cur = multisetDifference(i1, i2); sort(cur.begin(), cur.end()); cur.resize(unique(cur.begin(), cur.end()) - cur.begin()); for(int& x : cur) x ^= front; if(cur.empty() || cur.front() != front) cur.insert(cur.begin(), front); ansdep[i] = cur; for(int x : cur) ansdep[0].push_back(x); } sort(ansdep[0].begin(), ansdep[0].end()); ansdep[0].resize(unique(ansdep[0].begin(), ansdep[0].end()) - ansdep[0].begin()); propagate(1); vector<int> ans; collect(1, ans); return ans; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...