이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e5+10;
struct node
{
node *l, *r;
int v, res, sz, w, maiorV, maiorRes, lazy;
node(int vv, int rr)
{
v = maiorV = vv, res = maiorRes = rr;
sz = 1, lazy = 0, w = rand();
l = r = NULL;
}
};
typedef node*& node_t;
int sz(node *t) {return (t ? t->sz : 0);}
int maiorV(node *t) {return (t ? t->maiorV : -1);}
int maiorRes(node *t) {return (t ? t->maiorRes : -1);}
void op(node *t)
{
if (t)
{
t->sz = sz(t->l)+sz(t->r)+1;
t->maiorV = max({maiorV(t->l), maiorV(t->r), t->v});
t->maiorRes = max({maiorRes(t->l), maiorRes(t->r), t->res});
}
}
void flush(node *t)
{
if (!t) return;
if (t->l) t->l->lazy += t->lazy;
if (t->r) t->r->lazy += t->lazy;
t->res += t->lazy;
t->maiorRes = max(t->maiorRes, t->res);
t->lazy = 0;
}
void split(node *t, node_t l, node_t r, int pos, int add=0)
{
if (!t) return void(l=r=NULL);
flush(t);
int v = add+sz(t->l);
if (v >= pos) split(t->l, l, t->l, pos, add), r = t;
else split(t->r, t->r, r, pos, v+1), l = t;
op(t);
}
void merge(node_t t, node *l, node *r)
{
flush(l); flush(r);
if (!l || !r) t = (l ? l : r);
else if (l->w > r->w) merge(l->r, l->r, r), t = l;
else merge(r->l, l, r->l), t = r;
op(t);
}
void insert(node_t t, int pos, int v, int r)
{
node *t1 = NULL, *t2 = NULL;
node *aux = new node(v, r);
flush(t);
split(t, t1, t2, pos);
merge(t1, t1, aux);
merge(t, t1, t2);
op(t);
}
void erase(node_t t, int l, int r)
{
node *t1 = NULL, *t2 = NULL, *t3 = NULL;
flush(t);
split(t, t1, t2, l);
split(t2, t2, t3, r-l+1);
merge(t, t1, t3);
op(t);
}
int query(node *t, int l, int r, bool tipo)
{
node *t1 = NULL, *t2 = NULL, *t3 = NULL;
split(t, t1, t2, l);
split(t2, t2, t3, r-l+1);
int ans = (tipo == 0 ? t2->maiorV : t2->maiorRes);
merge(t2, t2, t3);
merge(t, t1, t2);
return ans;
}
int findV(node *t, int v)
{
if (!t->l && !t->r) return t->res;
else if (maiorV(t->l) == v) return findV(t->l, v);
return findV(t->r, v);
}
int findRes(node *t, int res)
{
if (!t->l && !t->r) return t->v;
else if (maiorRes(t->l) == res) return findRes(t->l, res);
return findRes(t->r, res);
}
int back[maxn];
int GetBestPosition(int N, int C, int R, int *K, int *S, int *E)
{
node *t = NULL;
for (int i = 0; i < N-1; i++)
{
insert(t, i, K[i], 0);
back[K[i]] = i;
}
insert(t, N-1, N, 0);
back[N] = N-1;
int ans = 0, pos = 0;
for (int i = 0; i < C; i++)
{
int l = S[i], r = E[i];
int mx = query(t, l, r-1, 0);
int mr = query(t, l, r, 1);
if (mr > ans)
{
ans = mr;
pos = back[findRes(t, mr)];
}
if (mx > R)
{
int ant = findV(t, mx);
erase(t, l, r);
insert(t, l, mx, ant);
}
else
{
int ant = findRes(t, mr);
erase(t, l, r);
insert(t, l, ant, mr+1);
}
}
int mr = query(t, 0, t->sz-1, 1);
if (mr > ans) pos = back[findRes(t, mr)];
return pos;
}
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |