Submission #776974

#TimeUsernameProblemLanguageResultExecution timeMemory
776974ind1vAddk (eJOI21_addk)C++11
0 / 100
32 ms4052 KiB
#include <bits/stdc++.h> using namespace std; const int N = 100005; const int K = 15; struct fenwick_tree { int64_t fenw[N]; void upd(int idx, int val) { for (; idx < N; idx |= (idx + 1)) { fenw[idx] += val; } } int64_t get(int idx) { int64_t res = 0; for (; idx >= 0; idx &= (idx + 1), --idx) { res += fenw[idx]; } return res; } int64_t get(int l, int r) { return get(r) - get(l - 1); } }; int n, k; int a[N]; int64_t p[N]; int idx[K]; int q; fenwick_tree ft1, ft2; void upd(int idx, int64_t val) { ft1.upd(idx, val); ft2.upd(idx, 1LL * idx * val); } int64_t get(int idx) { return 1LL * (idx + 1) * ft1.get(idx) - ft2.get(idx); } int64_t get(int l, int r) { return get(r) - get(l - 1); } int main() { ios::sync_with_stdio(false); cin.tie(0); cin >> n >> k; for (int i = 1; i <= n; i++) { cin >> a[i]; p[i] = a[i] + p[i - 1]; } for (int i = 1; i <= n; i++) { upd(i, p[i] - p[i - 1]); } cin >> q; while (q--) { int t; cin >> t; if (t == 1) { for (int i = 1; i <= k; i++) { cin >> idx[i]; } idx[k + 1] = idx[1]; for (int i = 1; i <= k; i++) { upd(idx[i], a[idx[i + 1]] - a[idx[i]]); } int tmp = a[idx[1]]; for (int i = 1; i <= k - 1; i++) { a[idx[i]] = a[idx[i + 1]]; } a[idx[k]] = tmp; } else if (t == 2) { int l, r, m; cin >> l >> r >> m; cout << get(min(l + m - 1, r), r) - get(l - 1, l + (r - min(l + m - 1, r) + 1) - 2) << '\n'; } } return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...