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 "plants.h"
#include "bits/stdc++.h"
using namespace std;
typedef long long ll;
typedef vector<int> vi;
typedef vector<vi> vvi;
typedef pair<int, int> pii;
typedef vector<pii> vpii;
#define sz(x) (int)(x).size()
#define all(x) (x).begin(), (x).end()
pii operator+(const pii &a, const pii &b)
{
return {a.first + b.first, a.second + b.second};
}
const int INF = 1 << 30;
int N, K;
vi A;
struct segtree
{
int size;
vpii arr;
vi op;
void init(vi &R)
{
size = 1;
while (size < sz(R))
size *= 2;
arr.assign(2 * size, {0, 0});
op.assign(2 * size, 0);
for (int i = 0; i < sz(R); ++i)
arr[i + size] = {R[i], i};
for (int i = size - 1; i > 0; --i)
arr[i] = min(arr[2 * i], arr[2 * i + 1]);
}
void propagate(int x)
{
if (x < size)
{
op[2 * x] += op[x];
op[2 * x + 1] += op[x];
}
arr[x] = arr[x] + make_pair(op[x], 0);
op[x] = 0;
}
void set(int i, int v) { set(i, v, 1, 0, size); }
void set(int i, int v, int x, int lx, int rx)
{
propagate(x);
if (rx - lx == 1)
{
arr[x] = {v, i};
return;
}
int m = (lx + rx) / 2;
if (i < m)
set(i, v, 2 * x, lx, m);
else
set(i, v, 2 * x + 1, m, rx);
propagate(2 * x), propagate(2 * x + 1);
arr[x] = min(arr[2 * x], arr[2 * x + 1]);
}
void add(int l, int r, int v)
{
if (l < 0)
add(l + N, N, v, 1, 0, size);
add(max(l, 0), r, v, 1, 0, size);
}
void add(int l, int r, int v, int x, int lx, int rx)
{
propagate(x);
if (l <= lx && rx <= r)
{
op[x] += v;
propagate(x);
return;
}
if (r <= lx || rx <= l)
return;
int m = (lx + rx) / 2;
add(l, r, v, 2 * x, lx, m);
add(l, r, v, 2 * x + 1, m, rx);
arr[x] = min(arr[2 * x], arr[2 * x + 1]);
}
pii query(int l, int r)
{
pii left = {INF, -1};
if (l < 0)
left = query(l + N, N, 1, 0, size);
pii right = query(max(l, 0), r, 1, 0, size);
if (left.first == right.first)
return left;
else
return min(left, right);
}
pii query(int l, int r, int x, int lx, int rx)
{
propagate(x);
if (l <= lx && rx <= r)
return arr[x];
if (r <= lx || rx <= l)
return {INF, -1};
int m = (lx + rx) / 2;
pii left = query(l, r, 2 * x, lx, m);
pii right = query(l, r, 2 * x + 1, m, rx);
return min(left, right);
}
void print()
{
for (int i = 0; i < size; ++i)
{
int j = i + size;
ll tmp = arr[j].first;
while (j > 0)
{
tmp += op[j];
j /= 2;
}
cout << tmp << " ";
}
cout << endl;
}
};
segtree seg;
void init(int _K, std::vector<int> r)
{
K = _K;
N = sz(r);
A.assign(N, -1);
seg.init(r);
for (int i = N; i > 0; --i)
{
pii cand = seg.query(0, N);
assert(cand.first == 0);
int idx = seg.query(cand.second - K + 1, cand.second + 1).second;
assert(idx != -1 && A[idx] == -1);
A[idx] = i;
seg.set(idx, INF);
seg.add(idx - K + 1, idx, -1);
}
return;
}
int compare_plants(int x, int y)
{
return (A[x] > A[y]) ? 1 : -1;
}
# | 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... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |
# | Verdict | Execution time | Memory | Grader output |
---|
Fetching results... |