Submission #750393

#TimeUsernameProblemLanguageResultExecution timeMemory
7503937as__7Sterilizing Spray (JOI15_sterilizing)C++17
0 / 100
5063 ms3904 KiB
#include <bits/stdc++.h> using namespace std; #define int long long #define pii pair<int, int> #define all(x) x.begin(),x.end() const int sz = 1e6 + 1, mod = 1e9 + 7, inf = -1e18; int N = 1, l, r; int seg[(int)3e5 + 1]; void upd(int idx, int x) { idx--; idx += N; seg[idx] = x; idx /= 2; while (idx) { seg[idx] = seg[idx * 2] + seg[idx * 2 + 1]; idx /= 2; } } int calc(int s, int e, int i) { if (s > r || e < l)return 0; if (s >= l && e <= r) { return seg[i]; } int md = (s + e) / 2; return calc(s, md, i * 2) + calc(md + 1, e, i * 2 + 1); } signed main() { int n,q,k; cin >> n >> q >> k; while (N < n)N *= 2; set<int>st; for (int i = 1; i <= n; i++) { int x; cin >> x; upd(i, x); st.insert(i); } st.insert(1e18); while (q--) { int o; cin >> o; if (o == 1) { int idx, x; cin >> idx >> x; upd(idx, x); } if (o == 2) { int ll, rr; cin >> ll >> rr; auto s = st.lower_bound(ll); auto e = st.upper_bound(rr); vector<int>v; while (s != e) { int idx = *s; upd(idx, seg[idx - 1 + N] / k); if (seg[idx - 1 + N] == 0)v.push_back(*s); s++; } for (auto i : v)st.erase(i); } if (o == 3) { cin >> l >> r; cout << calc(1, N, 1) << endl; } } }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...