Submission #964728

#TimeUsernameProblemLanguageResultExecution timeMemory
964728zxciganAddk (eJOI21_addk)C++17
36 / 100
2029 ms5796 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); vector<ll> ppref (n + 1); for (int i = 1; i <= n; ++i) cin >> a[i], pref[i] = pref[i - 1] + a[i]; for (int i = 1; i <= n; ++i) ppref[i] = ppref[i - 1] + pref[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; if (l == 1) { ans -= ppref[r - x]; } else { ans -= ppref[r - x] - ppref[l - 2]; } ans += ppref[r] - ppref[l + x - 2]; 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]; for (int i = 1; i <= n; ++i) ppref[i] = ppref[i - 1] + pref[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...