답안 #889910

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
889910 2023-12-20T09:37:25 Z avighna JJOOII 2 (JOI20_ho_t2) C++17
0 / 100
1 ms 348 KB
#include <bits/stdc++.h>

using namespace std;

#define ll long long

int main() {
  ios_base::sync_with_stdio(false);
  cin.tie(NULL);

  ll n, k;
  string s;
  cin >> n >> k >> s;

  string target = string(k, 'J') + string(k, 'O') + string(k, 'I');
  ll ptr = 0;
  ll mn = LLONG_MAX, mx = LLONG_MIN;
  for (ll i = 0; i < n && ptr < target.length(); ++i) {
    if (s[i] == target[ptr]) {
      mn = min(mn, i);
      mx = max(mx, i);
      ptr++;
    }
  }

  if (ptr != target.length()) {
    cout << "-1\n";
    return 0;
  }

  ptr--;
  for (ll i = mx; i >= 0 && ptr >= 0; --i) {
    if (s[i] == target[ptr]) {
      mn = min(mn, i);
      mx = max(mx, i);
      ptr--;
    }
  }

  cout << mx - mn + 1 - 3 * k << "\n";
}

Compilation message

ho_t2.cpp: In function 'int main()':
ho_t2.cpp:18:31: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   18 |   for (ll i = 0; i < n && ptr < target.length(); ++i) {
      |                           ~~~~^~~~~~~~~~~~~~~~~
ho_t2.cpp:26:11: warning: comparison of integer expressions of different signedness: 'long long int' and 'std::__cxx11::basic_string<char>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   26 |   if (ptr != target.length()) {
      |       ~~~~^~~~~~~~~~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Incorrect 0 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Incorrect 0 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 348 KB Output is correct
2 Incorrect 0 ms 348 KB Output isn't correct
3 Halted 0 ms 0 KB -