This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
#include <bits/stdc++.h>
using namespace std;
int n, res;
set<int> rem;
int a[200];
vector<int> Q;
int ask(int l, int lim) {
Q.clear();
for (int i = l; i <= lim; ++i) if (!a[i]) Q.push_back(i);
// assert(Q.size());
cout << Q.size() << ' ';
for (int i : Q) cout << i << ' ';
cout << endl;
cin >> res; return res;
}
void answer() {
cout << 0 << ' ';
for (int i = 1; i <= n; ++i) cout << a[i] << ' ';
cout << endl;
}
signed main() {
cin >> n; int l, r, mid, pt, num = 1, m;
for (int i = 1; i <= n; ++i) rem.insert(i);
while (rem.size()) {
pt = 0; m = *prev(rem.end());
// cout << "Remaining : ";
// for (int i : rem) cout << i << ' ';
// cout << endl;
if (ask(1, m) == 1) {
for (int i : rem) assert(!a[i]), a[i] = num;
break;
}
while (ask(1, m - 1) == ask(1, m) && pt < m) {
l = pt + 1; r = m - 1;
while (l <= r) {
mid = (l + r) / 2;
// assert(mid < m);
if (ask(mid, m) == ask(mid, m - 1)) l = mid + 1;
else r = mid - 1;
}
pt = l - 1;
assert(!a[pt]);
a[pt] = num;
// assert(rem.find(pt) != rem.end());
rem.erase(pt);
// cout << "found " << pt << " : " << a[pt] << "!!" << endl;
}
assert(!a[m]);
a[m] = num; rem.erase(m);
++num;
}
answer();
}
# | 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... |