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;
const int maxn = 200;
int qinit[maxn], ind[maxn];
int arr[maxn], n, br;
int query(int li, int ri, int i) {
int answ;
cout<<(ri-li+2)<<" ";
for(int i=li;i<=ri;i++) {
cout<<ind[i]<<" ";
} cout<<i<<"\n";
fflush(stdout);
cin>>answ;
return answ;
}
int bin_search(int i, int l, int r) {
int mid = (l+r)/2;
if(l==r) return l;
else {
if(query(l, mid, i) == (mid-l+1)) return bin_search(i, l, mid);
else return bin_search(i, mid+1,r);
}
}
void init() {
int answ;
for(int i=1;i<=n;i++) {
cout<<i<<" ";
for(int j=1;j<=i;j++) {
cout<<j<<" ";
} cout<<"\n";
fflush(stdout);
cin>>answ;
qinit[i] = answ;
}
br = 1;
for(int i=1;i<=n;i++) {
if(qinit[i] > qinit[i-1]) {
ind[br] = i;
arr[i] = br++;
}
}
br--;
for(int i=1;i<=n;i++) {
if(arr[i] == 0) {
arr[i] = bin_search(i, 1, br);
}
}
cout<<"0 ";
for(int i=1;i<=n;i++) {
cout<<arr[i]<<" ";
} cout<<"\n";
fflush(stdout);
}
int main() {
cin>>n;
init();
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... |