# | Time | Username | Problem | Language | Result | Execution time | Memory |
---|---|---|---|---|---|---|---|
641069 | ymm | Carnival (CEOI14_carnival) | C++17 | 0 ms | 0 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 Loop(x,l,r) for (ll x = (l); x < (r); ++x)
#define LoopR(x,l,r) for (ll x = (r)-1; x >= (l); --x)
typedef long long ll;
typedef std::pair<int, int> pii;
typedef std::pair<ll , ll > pll;
using namespace std;
const int N = 160;
int ans[N];
int n;
int ask(vector<int> v)
{
cout << v.size() << ' ';
for (int x : v)
cout << x+1 << ' ';
cout << '\n';
int ans;
cin >> ans;
return ans;
}
void solve(vector<int> v)
{
int len = v.size();
if (len == 1)
return;
solve(vector<int>(v.begin(), v.begin() + len/2));
solve(vector<int>(v.begin() + len/2, v.end()));
vector<vector<int>> cl, cr;
Loop (i,0,len/2) {
while (ans[v[i]] >= cl.size())
cl.emplace_back();
cl[ans[v[i]]].push_back(v[i]);
}
Loop (i,len/2,len) {
while (ans[v[i]] >= cr.size())
cr.emplace_back();
cr[ans[v[i]]].push_back(v[i]);
ans[v[i]] += cl.size();
}
Loop (i,0,cl.size())
assert(cl[i].size());
Loop (i,0,cr.size())
assert(cr[i].size());
vector<int> rem;
Loop (i,0,cl.size()) {
int l = 0, r = cr.size();
while (l < r) {
int m = (l + r + 1)/2;
vector<int> vec;
vec.push_back(cl[i][0]);
Loop (j,l,m) vec.push_back(cr[j][0]);
if (ask(vec) != vec.size())
r = m-1;
else
l = m;
}
if (l < cr.size()) {
for (int x : cr[l])
ans[x] = i;
rem.push_back(l + cl.size());
}
}
sort(rem.begin(), rem.end());
for (int x : vec) {
ans[x] -= lower_bound(rem.begin(), rem.end(), ans[x]) - rem.begin();
}
}
int main()
{
ios::sync_with_stdio(false);
cin >> n;
vector<int> vec(n);
iota(vec.begin(), vec.end(), 0);
solve(vec);
cout << "0 ";
Loop (i,0,n)
cout << ans[i]+1 << ' ';
cout << '\n';
}