This submission is migrated from previous version of oj.uz, which used different machine for grading. This submission may have different result if resubmitted.
/*#pragma GCC target ("avx2")
#pragma GCC optimize ("O3")
#pragma GCC optimize("Ofast")
#pragma GCC optimize ("unroll-loops")
#pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")/**/
#include<bits/stdc++.h>
typedef long long ll;
typedef long double ld;
#define llll std::pair<ll , ll>
#define pb push_back
#define fi first
#define sec second
#define all(a) a.begin() , a.end()
#define debug std::cout << "!!ALERT ALERT!!" << std::endl;
const ll limit = 1e18+7;
const ll sus = 150 + 5;
std::mt19937 rng(std::chrono::steady_clock::now().time_since_epoch().count());
ll rnd(ll a , ll b){
return (rng() % (b-a+1)) + a;
}
/*global variables*/
ll n;
ll par[sus] , sz[sus];
/**/
/*functions*/
ll fin(ll x){
if(par[x] == x){
return x;
}
return par[x] = fin(par[x]);
}
ll mrg(ll a , ll b){
a = fin(a);b = fin(b);
if(a == b){
return 0;
}
if(sz[a] < sz[b]){
std::swap(a , b);
}
par[b] = a;
sz[a] += sz[b];
return 1;
}
std::vector<ll> fun(ll l , ll r){
//std::cout << l << " " << r << std::endl;
if(l == r){
return std::vector<ll>{l};
}
ll md = (l + r) / 2;
std::vector<ll> lf = fun(l , md);
std::vector<ll> rs = fun(md+1 , r);
std::vector<ll> kd(rs.size() , 1);
for(ll i = 0;lf.size()>i;i++){
std::queue<llll> qu;qu.push({0 , rs.size()-1});
while(!qu.empty()){
llll a = qu.front();qu.pop();
std::cout << 1 + (a.sec - a.fi + 1) << " " << lf[i] << " ";
for(ll j = a.fi;a.sec >= j;j++){
std::cout << rs[j] << " ";
}
std::cout << std::endl;
ll o;std::cin >> o;
ll md = (a.fi + a.sec)/2;
if(o < 1 + (a.sec - a.fi + 1)){
if(a.fi == a.sec){
mrg(lf[i] , rs[a.sec]);
kd[a.sec] = 0;
continue;
}
qu.push( {a.fi , md});
qu.push({md+1,a.sec});
}
}
}
for(ll i = 0;rs.size()>i;i++){
if(kd[i]){
lf.pb(rs[i]);
}
}
return lf;
}
/**/
void solve(){
std::cin >> n;
for(ll i = 0;n>=i;i++){
par[i] = i;
sz[i] = 1;
}
fun(1 , n);
ll x = 1;
std::map<ll , ll> mp;
for(ll i = 1;n>=i;i++){
if(mp[fin(i)] == 0){
mp[fin(i)] = x++;
}
std::cout << mp[fin(i)] << " ";
}
std::cout << std::endl;
return;/**/
}
int main(){
//std::ios_base::sync_with_stdio(false);std::cin.tie(NULL);
/*#ifndef ONLINE_JUDGE
freopen("in.txt" , "r" , stdin);
freopen("out.txt" , "w" , stdout);
#endif*/
ll t = 1;
//std::cin >> t;
while(t--){
solve();
}
}
Compilation message (stderr)
carnival.cpp:5:78: warning: "/*" within comment [-Wcomment]
5 | #pragma GCC target("sse,sse2,sse3,ssse3,sse4,popcnt,abm,mmx,avx,tune=native")/**/
|
carnival.cpp: In function 'std::vector<long long int> fun(ll, ll)':
carnival.cpp:53:27: warning: comparison of integer expressions of different signedness: 'std::vector<long long int>::size_type' {aka 'long unsigned int'} and 'll' {aka 'long long int'} [-Wsign-compare]
53 | for(ll i = 0;lf.size()>i;i++){
| ~~~~~~~~~^~
carnival.cpp:75:27: warning: comparison of integer expressions of different signedness: 'std::vector<long long int>::size_type' {aka 'long unsigned int'} and 'll' {aka 'long long int'} [-Wsign-compare]
75 | for(ll i = 0;rs.size()>i;i++){
| ~~~~~~~~~^~
# | 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... |