# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
753757 | vjudge1 | Carnival (CEOI14_carnival) | C++17 | 2 ms | 2640 KiB |
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>
#define MaxN 100005
using namespace std;
int n;
vector<int> cLis[MaxN];
int ans[MaxN];
int main() {
scanf("%d", &n);
for(int c = 1; c <= n; ++c) cLis[c].clear();
for(int i = 1; i <= n; ++i) ans[i] = -1;
cLis[1].push_back(1);
ans[1] = 1;
int cnt = 1;
for(int i = 2; i <= n; ++i) {
int lo = 1, hi = cnt, pos = -1;
while(lo <= hi) {
int k = 1, mi = (lo+hi)/2;
printf("%d %d ", mi-lo+1 + 1, i);
for(int c = lo; c <= mi; ++c) printf("%d ", cLis[c][0]);
printf("\n");
scanf("%d", &k);
if (k > mi-lo+1) {
lo = mi+1;
}
else {
pos = mi;
hi = mi-1;
}
}
if (pos == -1) {
++cnt;
cLis[cnt].push_back(i);
ans[i] = cnt;
}
else {
cLis[pos].push_back(i);
ans[i] = pos;
}
}
printf("0 ");
for(int i = 1; i <= n; ++i) printf("%d ", ans[i]);
printf("\n");
return 0;
}
Compilation message (stderr)
# | 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... |