57002023-09-09 17:39:23TomaSajtSípálya (55 pont)cpp17Hibás válasz 7/5529ms12092 KiB
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;

vector<ll> range_maxes(const vector<ll>& v, int k) {
  int n = v.size();
  vector<ll> res(n - k + 1);
  deque<int> dq;
  for (int i = 0; i < n; i++) {
    while (!dq.empty() && i - dq.front() >= k) dq.pop_front();
    while (!dq.empty() && v[dq.back()] <= v[i]) dq.pop_back();
    dq.push_back(i);
    if (i - k + 1 >= 0) {
      res[i - k + 1] = v[dq.front()];
    }
  }
  return res;
}

int main() {
  cin.tie(0), ios::sync_with_stdio(0);

  int n, k;
  cin >> n >> k;

  vector<ll> v(n);
  for (auto& a : v) cin >> a;
  for (int i = 0; i < n; i++) v[i] += i;  // add the index, so that we now need to make flat regions instead of stairs

  vector<ll> maxes = range_maxes(v, k);  // maxes[i]: max value in the i-th K length interval

  vector<int> ps(n + 1);
  partial_sum(v.begin(), v.end(), ps.begin() + 1);

  ll best = LLONG_MAX;
  for (int i = 0; i <= n - k; i++) {
    int sum = ps[i + k] - ps[i];  // sum of values in the i-th K length interval
    ll cost = k * maxes[i] - sum;
    best = min(best, cost);
  }
  cout << best;
}
RészfeladatÖsszpontTesztVerdiktIdőMemória
base7/55
1Elfogadva0/03ms1976 KiB
2Hibás válasz0/02ms2192 KiB
3Hibás válasz0/23ms2164 KiB
4Hibás válasz0/23ms2292 KiB
5Hibás válasz0/23ms2552 KiB
6Hibás válasz0/23ms2888 KiB
7Hibás válasz0/33ms3220 KiB
8Elfogadva1/14ms3604 KiB
9Elfogadva1/14ms3816 KiB
10Elfogadva1/14ms3856 KiB
11Elfogadva1/14ms4104 KiB
12Elfogadva1/14ms4064 KiB
13Hibás válasz0/14ms4040 KiB
14Hibás válasz0/24ms3960 KiB
15Elfogadva2/24ms4124 KiB
16Hibás válasz0/229ms11332 KiB
17Hibás válasz0/228ms10048 KiB
18Hibás válasz0/228ms10016 KiB
19Hibás válasz0/328ms9332 KiB
20Hibás válasz0/229ms11444 KiB
21Hibás válasz0/229ms11672 KiB
22Hibás válasz0/229ms11668 KiB
23Hibás válasz0/228ms11884 KiB
24Hibás válasz0/229ms12092 KiB
25Hibás válasz0/228ms11576 KiB
26Hibás válasz0/229ms11604 KiB
27Hibás válasz0/228ms11576 KiB
28Hibás válasz0/328ms11596 KiB
29Hibás válasz0/328ms11448 KiB
30Hibás válasz0/328ms11448 KiB