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 "candies.h"
#include <bits/stdc++.h>
using namespace std;
#define inf 0x3F3F3F3F
const int MXN = 2e5 + 5;
array<long long, 2> st[MXN << 2];
long long lz[MXN << 2];
vector<array<long long, 2>> add[MXN], del[MXN];
array<long long, 2> combine(array<long long, 2> x, array<long long, 2> y)
{
return {min(x[0], y[0]), max(x[1], y[1])};
}
void relax(int l, int r, int x)
{
if (!lz[x]) return;
st[x][0] += lz[x], st[x][1] += lz[x];
if (l == r)
{
lz[x] = 0;
return;
}
lz[2*x] += lz[x], lz[2*x + 1] += lz[x];
lz[x] = 0;
}
void upd(int l, int r, int x, int lx, int rx, int val)
{
relax(l, r, x);
if (l > rx || r < lx) return;
if (l >= lx && r <= rx)
{
lz[x] += val;
relax(l, r, x);
return;
}
int mid = (l + r) >> 1;
upd(l, mid, 2*x, lx, rx, val);
upd(mid + 1, r, 2*x + 1, lx, rx, val);
st[x] = combine(st[2*x], st[2*x + 1]);
}
array<long long, 2> get(int l, int r, int x, int lx, int rx)
{
if (l > rx || r < lx) return {inf, -inf};
relax(l, r, x);
if (l >= lx && r <= rx) return st[x];
int mid = (l + r) >> 1;
return combine(get(l, mid, 2*x, lx, rx), get(mid + 1, r, 2*x + 1, lx, rx));
}
vector<int> distribute_candies(vector<int> c, vector<int> l, vector<int> r, vector<int> v)
{
int n = c.size(), q = l.size();
for (int i = 0; i < q; i++)
{
add[l[i]].push_back({i + 1, v[i]});
del[r[i]].push_back({i + 1, v[i]});
}
vector<int> res(n);
for (int i = 0; i < n; i++)
{
for (array<long long, 2> &x : add[i]) upd(0, q, 1, x[0], q, x[1]);
array<long long, 2> a = get(0, q, 1, 0, q);
long long val = get(0, q, 1, q, q)[0];
if (a[1] - a[0] <= c[i])
{
res[i] = val - a[0];
continue;
}
int l = 0, r = q;
while (l < r)
{
int mid = (l + r + 1) >> 1;
array<long long, 2> x = get(0, q, 1, mid, q);
if (a[1] - x[0] > c[i] || x[1] - a[0] > c[i]) l = mid;
else r = mid - 1;
}
array<long long, 2> f = get(0, q, 1, l, l);
if (a[1] - f[0] > c[i]) res[i] = (val - f[0]);
else if (f[1] - a[0] > c[i]) res[i] = (val - (f[1] - c[i]));
for (array<long long, 2> &x : del[i]) upd(0, q, 1, x[0], q, -x[1]);
}
return res;
}
# | 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... |