55922023-08-02 13:08:15TomaSajtUtazásszervezés (75 pont)cpp17Accepted 75/756ms5336 KiB
#include <bits/stdc++.h>
using namespace std;

const int K_MAX = 100000;

int main() {
  int guides, k, m, c;
  cin >> guides >> k >> m >> c;

  vector<int> requests(K_MAX + 1, 0);
  for (int i = 0; i < c; i++) {
    int s;
    cin >> s;
    requests[s] += 1;
    if (s > k - m + 1) return 1 / 0;
  }

  vector<int> guide_ends(K_MAX + 1, 0);
  int total = 0;

  for (int s = 1; s <= K_MAX - m + 1; s++) {
    int accepted = min(guides, requests[s]);
    total += accepted;
    guides -= accepted;
    guide_ends[s + m - 1] += accepted;
    guides += guide_ends[s];
  }
  cout << total;
}
SubtaskSumTestVerdictTimeMemory
base75/75
1Accepted0/04ms3232 KiB
2Accepted0/06ms3384 KiB
3Accepted3/33ms3664 KiB
4Accepted4/43ms3756 KiB
5Accepted4/43ms3944 KiB
6Accepted4/43ms4084 KiB
7Accepted4/43ms4256 KiB
8Accepted4/44ms4464 KiB
9Accepted5/54ms4672 KiB
10Accepted5/54ms4884 KiB
11Accepted6/64ms4968 KiB
12Accepted6/64ms4972 KiB
13Accepted6/64ms4972 KiB
14Accepted6/66ms5184 KiB
15Accepted6/66ms5268 KiB
16Accepted6/66ms5192 KiB
17Accepted6/66ms5336 KiB