#include <bits/stdc++.h>
using namespace std;
using ll = long long;
using vll = vector <ll>;
using ii = pair <ll, ll>;
using vii = vector <ii>;
ll fask (vll ve) {
if (ve.size() == 0) return 0;
cout << ve.size() << ' ';
for (ll i : ve) cout << i+1 << ' ';
cout << '\n' << flush;
ll res;
cin >> res;
return res;
}
void answer (vll ve) {
cout << "0 ";
for (ll i : ve) cout << i+1 << ' ';
cout << '\n' << flush;
}
int main () {
cin.tie(nullptr) -> sync_with_stdio(false);
ll n;
cin >> n;
vll key(n, -16);
ll timer = 0;
vll g = {};
for (ll i = 0; i < n; i++) {
ll l = 0, r = g.size()+1;
while (l+1 < r) {
ll mid = (l+r)/2;
vll h(g.begin(), g.begin()+mid); // grab the first mid elements
h.push_back(i);
if (fask(h) == h.size()) { // i is unique among the first mid elemnts
l = mid;
} else {
r = mid;
}
}
if (l == g.size()) {
g.push_back(i);
key[i] = timer++;
} else {
key[i] = key[l];
}
}
answer(key);
return 0;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |