Submission #155005

#TimeUsernameProblemLanguageResultExecution timeMemory
155005jovan_bMonkey and Apple-trees (IZhO12_apple)C++17
0 / 100
3 ms504 KiB
#include <bits/stdc++.h> using namespace std; typedef long long ll; typedef long double ld; int c; const int INF = 1000000000; struct segment{ int val; int l, r; } seg[4000000]; int cnt = 1; void create(int node, int l, int r){ seg[node].l = ++cnt; seg[node].r = ++cnt; int mid = (l+r)/2; if(seg[node].val){ seg[cnt-1].val = mid-l+1; seg[cnt].val = r-mid; } } void upd(int node, int l, int r, int tl, int tr){ if(tl > r || l > tr) return; if(tl <= l && r <= tr){ seg[node].val = r-l+1; return; } int mid = (l+r)/2; if(!seg[node].l) create(node, l, r); upd(seg[node].l, l, mid, tl, tr); upd(seg[node].r, mid+1, r, tl, tr); seg[node].val = seg[seg[node].l].val + seg[seg[node].r].val; } int query(int node, int l, int r, int tl, int tr){ if(tl > r || l > tr) return 0; if(tl <= l && r <= tr) return seg[node].val; int mid = (l+r)/2; if(!seg[node].l) create(node, l, r); return query(seg[node].l, l, mid, tl, tr) + query(seg[node].r, mid+1, r, tl, tr); } int main(){ ios_base::sync_with_stdio(false); cin.tie(0); cout.precision(10); cout << fixed; int m; cin >> m; while(m--){ int a, l, r; cin >> a >> l >> r; l += c; r += c; if(a == 2){ upd(1, 1, INF, l, r); } if(a == 1){ c = query(1, 1, INF, l, r); cout << c << "\n"; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...