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;
using ll = long long;
using ull = unsigned long long;
using ld = long double;
#define pll pair <ll,ll>
#define fi first
#define se second
#define sz(a) (ll((a).size()))
#define BIT(mask,i) (((mask) >> (i))&1LL)
#define MASK(i) (1LL << (i))
#define MP make_pair
const ll MAXN = 1e5;
#include "assistant.h"
#include "advisor.h"
namespace {
namespace penis{
ll c[MAXN+100];
vector <ll> pos[MAXN+100];
vector <ll> event[MAXN+100];
ll n,k;
void advisor(){
set <pll> s;
for (ll i = n-1;i >= 0;i--){
pos[i].push_back(n+1);
}
for (ll i = n-1;i >= 0;i--){
pos[c[i]].push_back(i);
}
for (ll i = 0;i < k;i ++){s.insert(MP(pos[i].back(),i));event[i].push_back(-1);}
for (ll i = 0;i < n;i ++){
if (s.insert(MP(i,c[i])).se){
event[c[i]].push_back(i);
pll tmp = *s.rbegin();
s.erase(s.find(tmp));
event[tmp.se].push_back(i);
}
s.erase(MP(i,c[i]));
pos[c[i]].pop_back();
s.insert(MP(pos[c[i]].back(),c[i]));
}
for (ll i = 0;i < n;i ++)pos[i].clear();
for (ll i = 0;i < n;i ++)pos[c[i]].push_back(i);
auto cnt = [&](ll color,ll l,ll r){
return upper_bound(pos[color].begin(),pos[color].end(),r)-lower_bound(pos[color].begin(),pos[color].end(),l);
};
vector <pll> all_event;
for (ll i = 0;i < n;i ++){
if (sz(event[i])%2==1)event[i].push_back(n+1);
for (ll j = 0;j < sz(event[i]);j += 2){
all_event.push_back(MP(event[i][j] == -1 ? i - k : event[i][j],cnt(i,event[i][j]+1,event[i][j+1])));
}
}
sort(all_event.begin(),all_event.end());
for (auto x:all_event){
while (x.se--){
WriteAdvice(1);
}
WriteAdvice(0);
}
}
}
namespace pussy{
ll hint[MAXN*2+100];
ll n,k;
ll ptr;
ll life[MAXN*2+100];
bool in_s[MAXN+100];
ll get_hint(){
ll cnt = 0;
while (hint[ptr]==1)ptr++,cnt++;
ptr++;
// cout<<"GET "<<cnt<<endl;
return cnt;
}
void assistant(){
set <pll> s;
for (ll i = 0;i < k;i ++){life[i] = get_hint();s.insert({life[i],i});in_s[i] = 1;}
for (ll i = 0;i < n;i ++){
ll x = GetRequest();
if (in_s[x]){
life[x]--;
}
else{
pll tmp = *s.begin();
in_s[tmp.se]=0;
PutBack(tmp.se);
s.erase(tmp);
life[x] = get_hint();
s.insert({life[x],x});
in_s[x] = 1;
}
}
}
}
}
void ComputeAdvice(int *C, int N, int K, int M) {
using namespace penis;
for (ll i = 0;i < N;i ++){c[i] = C[i];}
n=N;
k=K;
penis::advisor();
}
#include<bits/stdc++.h>
using namespace std;
using ll = long long;
using ull = unsigned long long;
using ld = long double;
#define pll pair <ll,ll>
#define fi first
#define se second
#define sz(a) (ll((a).size()))
#define BIT(mask,i) (((mask) >> (i))&1LL)
#define MASK(i) (1LL << (i))
#define MP make_pair
const ll MAXN = 1e5;
#include "assistant.h"
#include "advisor.h"
namespace {
namespace penis{
ll c[MAXN+100];
vector <ll> pos[MAXN+100];
vector <ll> event[MAXN+100];
ll n,k;
void advisor(){
set <pll> s;
for (ll i = n-1;i >= 0;i--){
pos[i].push_back(n+1);
}
for (ll i = n-1;i >= 0;i--){
pos[c[i]].push_back(i);
}
for (ll i = 0;i < k;i ++){s.insert(MP(pos[i].back(),i));event[i].push_back(-1);}
for (ll i = 0;i < n;i ++){
if (s.insert(MP(i,c[i])).se){
event[c[i]].push_back(i);
pll tmp = *s.rbegin();
s.erase(s.find(tmp));
event[tmp.se].push_back(i);
}
s.erase(MP(i,c[i]));
pos[c[i]].pop_back();
s.insert(MP(pos[c[i]].back(),c[i]));
}
for (ll i = 0;i < n;i ++)pos[i].clear();
for (ll i = 0;i < n;i ++)pos[c[i]].push_back(i);
auto cnt = [&](ll color,ll l,ll r){
return upper_bound(pos[color].begin(),pos[color].end(),r)-lower_bound(pos[color].begin(),pos[color].end(),l);
};
vector <pll> all_event;
for (ll i = 0;i < n;i ++){
if (sz(event[i])%2==1)event[i].push_back(n+1);
for (ll j = 0;j < sz(event[i]);j += 2){
all_event.push_back(MP(event[i][j] == -1 ? i - k : event[i][j],cnt(i,event[i][j]+1,event[i][j+1])));
}
}
sort(all_event.begin(),all_event.end());
for (auto x:all_event){
while (x.se--){
WriteAdvice(1);
}
WriteAdvice(0);
}
}
}
namespace pussy{
ll hint[MAXN*2+100];
ll n,k;
ll ptr;
ll life[MAXN*2+100];
bool in_s[MAXN+100];
ll get_hint(){
ll cnt = 0;
while (hint[ptr]==1)ptr++,cnt++;
ptr++;
// cout<<"GET "<<cnt<<endl;
return cnt;
}
void assistant(){
set <pll> s;
for (ll i = 0;i < k;i ++){life[i] = get_hint();s.insert({life[i],i});in_s[i] = 1;}
for (ll i = 0;i < n;i ++){
ll x = GetRequest();
if (in_s[x]){
life[x]--;
}
else{
pll tmp = *s.begin();
in_s[tmp.se]=0;
PutBack(tmp.se);
s.erase(tmp);
life[x] = get_hint();
s.insert({life[x],x});
in_s[x] = 1;
}
}
}
}
}
void Assist(unsigned char *A, int N, int K, int R) {
using namespace pussy;
for (ll i = 0;i < R;i ++)hint[i]=A[i];
n=N,k=K;
pussy::assistant();
}
Compilation message (stderr)
advisor.cpp:77:14: warning: 'void {anonymous}::pussy::assistant()' defined but not used [-Wunused-function]
77 | void assistant(){
| ^~~~~~~~~
assistant.cpp:23:14: warning: 'void {anonymous}::penis::advisor()' defined but not used [-Wunused-function]
23 | void advisor(){
| ^~~~~~~
# | 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... |