結果
問題 | No.252 "良問"(良問とは言っていない (2) |
ユーザー |
![]() |
提出日時 | 2017-03-09 14:25:14 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 894 bytes |
コンパイル時間 | 873 ms |
コンパイル使用メモリ | 76,504 KB |
実行使用メモリ | 39,680 KB |
最終ジャッジ日時 | 2024-06-23 23:58:59 |
合計ジャッジ時間 | 1,770 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 5 WA * 2 |
ソースコード
#include <string>#include <vector>#include <iostream>#include <algorithm>using namespace std;int Q; string s, t1 = "good", t2 = "problem";int main() {cin >> Q;while (Q--) {cin >> s;vector<vector<int> > sum(8, vector<int>(s.size() + 1));for (int i = 0; i <= s.size() - 7; i++) {int cnt = 0;for (int j = 0; j < 7; j++) {if (s[i + j] != t2[j]) cnt++;}sum[cnt][i + 1]++;}for (int i = 0; i <= 7; i++) {for (int j = 0; j < s.size(); j++) {sum[i][j + 1] += sum[i][j];}}int ret = 999999999;for (int i = 0; i <= s.size() - 11; i++) {int cnt = 0;for (int j = 0; j < 4; j++) {if (s[i + j] != t1[j]) cnt++;}for (int j = 0; j <= 7; j++) {if (sum[j][s.size()] - sum[j][i + 4]) {ret = min(ret, cnt + j + (i >= 7 && sum[0][i - 6]));}}if (cnt == 0) break;}cout << ret << endl;}return 0;}