Submission #670654

#TimeUsernameProblemLanguageResultExecution timeMemory
670654Koful123Monkey and Apple-trees (IZhO12_apple)C++17
0 / 100
436 ms262144 KiB
#include <bits/stdc++.h> using namespace std; #define int long long #define endl "\n" #define pb push_back #define ff first #define ss second #define all(x) (x).begin(), (x).end() #define rall(x) (x).rbegin(), (x).rend() struct node{ int sum,lazy,l,r,tl,tr; node(): sum(0), lazy(0), l(0), r(0), tl(1), tr(1e9) {}; }; struct SegTree{ vector<node> seg; SegTree(){ seg.pb(node()); }; void push(int v,int tl,int tr){ int tm = (tl + tr) / 2; if(seg[v].l == 0){ seg[v].l = seg.size(); seg.pb(node()); seg[seg[v].l].tl = tl; seg[seg[v].l].tr = tm; } if(seg[v].r == 0){ seg[v].r = seg.size(); seg.pb(node()); seg[seg[v].r].tl = tm + 1; seg[seg[v].r].tr = tr; } assert(seg.size() <= 1e7); if(!seg[v].lazy) return; seg[seg[v].r].lazy = seg[v].lazy; seg[seg[v].r].sum = seg[v].lazy * (tr - tm); seg[seg[v].l].lazy = seg[v].lazy; seg[seg[v].l].sum = seg[v].lazy * (tm - tl + 1); seg[v].lazy = 0; } void upd(int v,int l,int r,int tl,int tr,int x){ if(tl > r || tr < l) return; if(tl >= l && tr <= r){ seg[v].sum = (tr - tl + 1) * x; seg[v].lazy = x; return; }; push(v,tl,tr); int tm = (tl + tr) / 2; upd(seg[v].l,l,r,tl,tm,x), upd(seg[v].r,l,r,tm+1,tr,x); seg[v].sum = seg[seg[v].l].sum + seg[seg[v].r].sum; } int get(int v,int tl,int tr,int l,int r){ if(tl > r || tr < l) return 0; if(tl >= l && tr <= r){ return seg[v].sum; } push(v,tl,tr); int tm = (tl + tr) / 2; return get(seg[v].l,tl,tm,l,r) + get(seg[v].r,tm+1,tr,l,r); } int get(int l,int r){ return get(0,1,1e9,l,r); } }; void solve(){ SegTree seg; int q,c = 0; cin >> q; for(int i = 0; i < q; i++){ int ty,l,r; cin >> ty >> l >> r; if(ty == 2){ seg.upd(0,l + c,r + c,1,1e9,1); } else{ int res = seg.get(l+c,r+c); cout << res << endl; c = res; } } } signed main(){ ios::sync_with_stdio(0); cin.tie(0); int t = 1; // cin >> t; while(t--) solve(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...