Submission #964726

#TimeUsernameProblemLanguageResultExecution timeMemory
964726zxciganAddk (eJOI21_addk)C++17
36 / 100
2060 ms3084 KiB
#include <bits/stdc++.h> using namespace std; using ll = long long; using ld = long double; const int N = 1e6 + 1; const int mod = 1e9 + 7; template <typename T> bool umx(T& a, T b) { return (a < b ? a = b, 1 : 0); } template <typename T> bool umn(T& a, T b) { return (a > b ? a = b, 1 : 0); } void solve () { int n, k; cin >> n >> k; vector<int> a(n + 1); vector<ll> pref (n + 1); for (int i = 1; i <= n; ++i) cin >> a[i], pref[i] = pref[i - 1] + a[i]; int q; cin >> q; while (q--) { int type; cin >> type; if (type == 2) { int l, r, x; cin >> l >> r >> x; ll ans = 0; for (int i = l; i <= r; ++i) { if (i <= r - x + 1) ans += pref[i + x - 1] - pref[i - 1]; } cout << ans << "\n"; } else { vector<int> ve(k); for (int i = 0; i < k; ++i) cin >> ve[i]; int last = a[ve[0]]; for (int i = 0; i < k - 1; ++i) a[ve[i]] = a[ve[i + 1]]; a[ve.back()] = last; for (int i = 1; i <= n; ++i) pref[i] = pref[i - 1] + a[i]; } } } signed main() { #ifdef LOCAL freopen("input.txt", "r", stdin); freopen("output.txt", "w", stdout); #else // freopen ("input.txt", "r", stdin); // freopen ("output.txt", "w", stdout); #endif ios_base::sync_with_stdio(false); cin.tie(nullptr); int T = 1; while (T--) solve(); return 0; }
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...