Submission #1298134

#TimeUsernameProblemLanguageResultExecution timeMemory
1298134lmquan Martian DNA (BOI18_dna)C++20
100 / 100
23 ms3020 KiB
#define taskname ""
#include <bits/stdc++.h>
using namespace std;

int main() {
  if (fopen(taskname".inp", "r")) {
    freopen(taskname".inp", "r", stdin);
    freopen(taskname".out", "w", stdout);
  }
  ios_base::sync_with_stdio(false);
  cin.tie(nullptr);

  int n, k, r;
  cin >> n >> k >> r;
  vector<int> d(n + 1);
  for (int i = 1; i <= n; i++) {
    cin >> d[i];
  }
  vector<int> e(k);
  for (int i = 1; i <= r; i++) {
    int b, q;
    cin >> b >> q;
    e[b] = q;
  }
  
  vector<int> a(k, 0);
  int j = 0, t = r, result = n + 1;
  for (int i = 1; i <= n; i++) {
    while (t > 0 && j < n) {
      int x = d[++j];
      a[x]++;
      if (a[x] == e[x]) {
        t--;
      }
    }
    if (t == 0) {
      result = min(result, j - i + 1);
      a[d[i]]--;
      if (a[d[i]] == e[d[i]] - 1) {
        t++;
      }
    } else {
      break;
    }
  }

  if (result > n) {
    cout << "impossible";
  } else {
    cout << result;
  }

  return 0;
}

Compilation message (stderr)

dna.cpp: In function 'int main()':
dna.cpp:7:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
    7 |     freopen(taskname".inp", "r", stdin);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~
dna.cpp:8:12: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
    8 |     freopen(taskname".out", "w", stdout);
      |     ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...