이 제출은 이전 버전의 oj.uz에서 채점하였습니다. 현재는 제출 당시와는 다른 서버에서 채점을 하기 때문에, 다시 제출하면 결과가 달라질 수도 있습니다.
#include "elephants.h"
#include <map>
#include <unordered_map>
#include <set>
#include <iostream>
using namespace std;
const int N = 1e5 + 30;
const int T = 69;
int n, l, fr, sc;
int x[N];
map <int, int> mp;
unordered_map <int, int> nax, haj, a, b;
set <int> fp;
void go(int x)
{
int sm = 1, s = 0;
int nx = x, v = x;
while (s < T)
{
s++;
if (v > nx + l) sm++, nx = v;
if (v == sc) break;
v = haj[v];
}
a[x] = sm;
b[x] = nx + l;
}
void add(int x)
{
mp[x]++;
auto i1 = fp.lower_bound(x);
if (i1 != fp.end()) haj[x] = *i1, nax[*i1] = x;
if (i1 != fp.begin()) nax[x] = *(--i1), haj[*i1] = x;
fp.insert(x);
fr = *fp.begin(), sc = *(--fp.end());
int v = x;
for (int i = 0; i <= T; i++)
{
go(v);
if (v == fr) break;
v = nax[v];
}
}
void rmv(int x)
{
mp[x]--;
haj[nax[x]] = haj[x];
nax[haj[x]] = nax[x];
nax[x] = haj[x] = 0;
fp.erase(x);
fr = *fp.begin(), sc = *(--fp.end());
int v = x;
for (int i = 0; i <= T; i++)
{
if (v == fr) break;
v = nax[v];
go(v);
}
}
int ans()
{
int v = fr, ret = 0;
while (v < sc)
{
ret += a[v];
if (b[v] >= sc) break;
v = *fp.lower_bound(b[v] + 1);
}
return ret;
}
void init(int N, int L, int X[])
{
n = N; l = L;
for (int i = 0; i < n; i++)
{
x[i] = X[i];
//cout << x[i] << endl;
if (mp[x[i]] == 0) add(x[i]);
else mp[x[i]]++;
}
}
int update(int i, int y)
{
if (mp[x[i]] == 1) rmv(x[i]);
else mp[x[i]]--;
x[i] = y;
if (mp[y] == 0) add(y);
else mp[y]++;
return ans();
}
# | 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... |