This documentation is automatically generated by competitive-verifier/competitive-verifier
// competitive-verifier: PROBLEM https://yukicoder.me/problems/no/618
#include <algorithm>
#include <cstdint>
#include <iostream>
#include <limits>
#include <vector>
#include "algorithm/compress.hpp"
#include "segtree/segment_tree.hpp"
struct S {
std::int64_t x, s;
};
struct M {
using T = S;
using value_type = T;
static constexpr T id() {
return T(std::numeric_limits<std::int64_t>::max() / 2, 0);
}
static constexpr T op(const T& lhs, const T& rhs) {
return S{std::min(lhs.x, rhs.x), lhs.s + rhs.s};
}
};
int main(void) {
int q;
std::cin >> q;
std::vector<int> t(q), x(q);
for (int i = 0; i < q; ++i) std::cin >> t[i] >> x[i];
std::int64_t s = 0;
std::vector<std::int64_t> a;
for (int i = 0; i < q; ++i) {
if (t[i] == 1)
a.emplace_back(x[i] - s);
else if (t[i] == 3)
s += x[i];
}
s = 0;
coordinate_compression cps(a);
segment_tree<M> st(cps.size());
std::vector<std::int64_t> c;
for (int i = 0; i < q; ++i) {
if (t[i] == 1) {
int k = cps.get(x[i] - s);
c.emplace_back(x[i] - s);
st.set(k, S{x[i] - s, st.get(k).s + 1});
} else if (t[i] == 2) {
int k = cps.get(c[x[i] - 1]);
st.set(k, S{c[x[i] - 1], st.get(k).s - 1});
} else {
s += x[i];
}
auto f = [&](S y) {
return y.x + s >= y.s;
};
int k = st.min_left(f);
auto t = st.prod(k, cps.size());
std::int64_t ans = std::min(t.x + s, t.s);
if (k > 0) {
t = st.prod(k - 1, cps.size());
ans = std::max(ans, std::min(t.x + s, t.s));
}
std::cout << ans << '\n';
}
return 0;
}
Traceback (most recent call last):
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/resolver.py", line 291, in resolve
bundled_code = language.bundle(path, basedir=basedir)
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus.py", line 242, in bundle
bundler.update(path)
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus_bundle.py", line 479, in update
self._resolve(pathlib.Path(included), included_from=path)
File "/home/runner/.local/lib/python3.12/site-packages/competitive_verifier/oj/verify/languages/cplusplus_bundle.py", line 286, in _resolve
raise BundleErrorAt(path, -1, "no such header")
competitive_verifier.oj.verify.languages.cplusplus_bundle.BundleErrorAt: algorithm/compress.hpp: line -1: no such header
| Env | Name | Status | Elapsed | Memory |
|---|---|---|---|---|
| g++ | 00_sample |
|
2 ms | 3 MB |
| g++ | 01_sample |
|
2 ms | 4 MB |
| g++ | 02_sample |
|
2 ms | 3 MB |
| g++ | 03_sample |
|
2 ms | 3 MB |
| g++ | random00 |
|
3 ms | 4 MB |
| g++ | random01 |
|
3 ms | 4 MB |
| g++ | random02 |
|
2 ms | 4 MB |
| g++ | random03 |
|
2 ms | 4 MB |
| g++ | random04 |
|
2 ms | 4 MB |
| g++ | random05 |
|
2 ms | 4 MB |
| g++ | random06 |
|
3 ms | 4 MB |
| g++ | random07 |
|
2 ms | 4 MB |
| g++ | random08 |
|
2 ms | 3 MB |
| g++ | random09 |
|
3 ms | 4 MB |
| g++ | random10 |
|
2 ms | 3 MB |
| g++ | random11 |
|
3 ms | 4 MB |
| g++ | random12 |
|
3 ms | 4 MB |
| g++ | random13 |
|
2 ms | 3 MB |
| g++ | random14 |
|
3 ms | 4 MB |
| g++ | random15 |
|
73 ms | 7 MB |
| g++ | random16 |
|
75 ms | 7 MB |
| g++ | random17 |
|
74 ms | 7 MB |
| g++ | random18 |
|
74 ms | 7 MB |
| g++ | random19 |
|
73 ms | 7 MB |
| g++ | random20 |
|
74 ms | 7 MB |
| g++ | random21 |
|
75 ms | 7 MB |
| g++ | random22 |
|
74 ms | 7 MB |
| g++ | random23 |
|
77 ms | 7 MB |
| g++ | random24 |
|
74 ms | 7 MB |
| g++ | random25 |
|
74 ms | 7 MB |
| g++ | random26 |
|
75 ms | 7 MB |
| g++ | random27 |
|
76 ms | 7 MB |
| g++ | random28 |
|
75 ms | 7 MB |
| g++ | random29 |
|
75 ms | 7 MB |
| g++ | random30 |
|
94 ms | 12 MB |
| g++ | random31 |
|
86 ms | 12 MB |
| g++ | random32 |
|
52 ms | 6 MB |
| g++ | random33 |
|
76 ms | 8 MB |
| g++ | random34 |
|
2 ms | 4 MB |