제출 #947804

#제출 시각아이디문제언어결과실행 시간메모리
947804THXuan원숭이와 사과 나무 (IZhO12_apple)C++14
100 / 100
221 ms139860 KiB
#include <iostream> #include <vector> #include <algorithm> #include <set> #include <map> #define INF 1e18 using namespace std; typedef long long ll; const int MAXN = 5e6; ll t[MAXN], lazy[MAXN], lf[MAXN], rg[MAXN]; int node_count = 1; int create_node() { node_count++; return node_count; } void pushdown(int v, int l, int r) { int tm = (l + r) / 2; if (lf[v] == 0) lf[v] = create_node(); if (rg[v] == 0) rg[v] = create_node(); if (lazy[v]) { lazy[lf[v]] = 1; lazy[rg[v]] = 1; t[lf[v]] = (tm - l + 1); t[rg[v]] = (r - tm); lazy[v] = 0; } } void upd(int v, int l, int r, int tl, int tr, ll val) { if (l > r)return; if (l == tl && r == tr) { lazy[v] = val; t[v] = (r - l + 1); return; } pushdown(v, tl, tr); int tm = (tl + tr) / 2; if (r <= tm) { if (lf[v] == 0) lf[v] = create_node(); upd(lf[v], l, r, tl, tm, val); } else if (l >= tm + 1) { if (rg[v] == 0) rg[v] = create_node(); upd(rg[v], l, r, tm + 1, tr, val); } else { if (lf[v] == 0) lf[v] = create_node(); if (rg[v] == 0) rg[v] = create_node(); upd(lf[v], l, tm, tl, tm, val); upd(rg[v], tm + 1, r, tm + 1, tr, val); } t[v] = t[lf[v]] + t[rg[v]] + lazy[v] * (tr - tl + 1); } ll query(int v, int tl, int tr, int l, int r) { if (l > r)return 0; if (l == tl && r == tr)return t[v]; pushdown(v, tl, tr); int tm = (tl + tr) / 2; if (r <= tm)return query(lf[v], tl, tm, l, r); else if (l > tm)return query(rg[v], tm + 1, tr, l, r); else { ll left = query(lf[v], tl, tm, l, tm); ll right = query(rg[v], tm + 1, tr, tm + 1, r); return left + right; } } void solve() { int m; cin >> m; int c = 0; while (m--) { int type; cin >> type; int l, r; cin >> l >> r; if (type == 1) { c = query(1, 1, 1000000005, l + c, r + c); cout << c << "\n"; } else { upd(1, l + c, r + c, 1, 1000000005, 1); } } } int main() { ios_base::sync_with_stdio(0); cin.tie(0); int t = 1;// cin>>t; while (t--) solve(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...