結果
問題 | No.876 Range Compress Query |
ユーザー |
![]() |
提出日時 | 2019-09-06 22:41:00 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 483 ms / 2,000 ms |
コード長 | 4,850 bytes |
コンパイル時間 | 1,234 ms |
コンパイル使用メモリ | 100,572 KB |
実行使用メモリ | 11,504 KB |
最終ジャッジ日時 | 2024-06-24 20:12:46 |
合計ジャッジ時間 | 5,731 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 18 |
ソースコード
#include <iostream>#include <cstdio>#include <cstdlib>#include <cmath>#include <functional>#include <algorithm>#include <string>#include <vector>#include <set>#include <map>#include <queue>#include <stack>using namespace std;template<class T, class Compare = less<T> >using MaxHeap = priority_queue<T, vector<T>, Compare>;template<class T, class Compare = greater<T> >using MinHeap = priority_queue<T, vector<T>, Compare>;using llong = long long;//===template<typename Monoid, typename Laz>struct LazySegmentTree {const function<Monoid(Monoid, Monoid)> mergeMonoid;const function<Monoid(Monoid, Laz, int)> applyLaz;const function<Laz(Laz, Laz)> mergeLaz;const Monoid e; // neutral elementvector<Monoid> seg;vector<Laz> lazy;vector<bool> isUpdated;int size;LazySegmentTree(int nmemb, const Monoid &e,function<Monoid(Monoid, Monoid)> f,function<Monoid(Monoid, Laz, int)> g,function<Laz(Laz, Laz)> h):e(e), mergeMonoid(f), applyLaz(g), mergeLaz(h){size = 1;while (size < nmemb) {size *= 2;}seg.assign(2 * size - 1, e);isUpdated.assign(2 * size - 1, true);lazy.resize(2 * size - 1);}inline void propagation(int k, int len) {if (!isUpdated[k]) {seg[k] = applyLaz(seg[k], lazy[k], len);if (len > 1) {if (isUpdated[2 * k + 1])lazy[2 * k + 1] = lazy[k], isUpdated[2 * k + 1] = false;elselazy[2 * k + 1] = mergeLaz(lazy[2 * k + 1], lazy[k]);if (isUpdated[2 * k + 2])lazy[2 * k + 2] = lazy[k], isUpdated[2 * k + 2] = false;elselazy[2 * k + 2] = mergeLaz(lazy[2 * k + 2], lazy[k]);}isUpdated[k] = true;}}Monoid update(int k, int nl, int nr, int ql, int qr, Laz dat) {propagation(k, nr - nl);if (nr <= ql || qr <= nl) return seg[k];if (ql <= nl && nr <= qr) {lazy[k] = dat;isUpdated[k] = false;propagation(k, nr - nl);return seg[k];}else {seg[k] = mergeMonoid(update(2 * k + 1, nl, (nl + nr) / 2, ql, qr, dat),update(2 * k + 2, (nl + nr) / 2, nr, ql, qr, dat));return seg[k];}}// [l, r) <= datvoid update(int l, int r, Laz dat) {update(0, 0, size, l, r, dat);}Monoid query(int k, int nl, int nr, int ql, int qr) {propagation(k, nr - nl);if (nr <= ql || qr <= nl) return e;if (ql <= nl && nr <= qr) return seg[k];else return mergeMonoid(query(2 * k + 1, nl, (nl + nr) / 2, ql, qr),query(2 * k + 2, (nl + nr) / 2, nr, ql, qr));}// [l, r)Monoid query(int l, int r) { return query(0, 0, size, l, r); }Monoid operator [](const int &k) { return query(k, k + 1); }};//===struct P {llong l, r;llong length;P (){}P (const P &m) { *this = m; };P (llong l, llong r, llong len):l(l), r(r), length(len) {};P operator + (const P &r) const {const P &l = *this;if (l.r == -1) return r;if (r.r == -1) return l;P ret;ret.l = l.l;ret.r = r.r;ret.length = l.length + r.length;if (l.r == r.l) ret.length--;return ret;};};llong n, q;llong com, l, r;int main() {cin >> n >> q;LazySegmentTree<P, llong> seg(n, P(-1, -1, 1),[](P l, P r){return l + r;},[](P m, llong v, int len) {P ret;ret.l = m.l + v;ret.r = m.r + v;ret.length = m.length;return ret;},[](llong l, llong r) {return l + r;});for (int i = 0; i < n; i++) {llong v;cin >> v;seg.update(i, i + 1, v + 1);}for (int i = 0; i < q; i++) {cin >> com >> l >> r;l--; r--;if (com == 1) {llong v;cin >> v;seg.update(l, r + 1, v);}else if (com == 2) {P a = seg.query(l, r + 1);cout << a.length << endl;}}return 0;}