Submission #964712

#TimeUsernameProblemLanguageResultExecution timeMemory
964712zxciganAddk (eJOI21_addk)C++17
0 / 100
1691 ms2988 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); for (int i = 1; i <= n; ++i) cin >> 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) { // cout << min (r - x + 1 - l + 1, i - l + 1) << endl; ans += 1LL * a[i] * min ({r - i + 1, x, i - l + 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; } } } 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...