結果
問題 | No.150 "良問"(良問とは言っていない |
ユーザー |
![]() |
提出日時 | 2017-03-09 14:45:59 |
言語 | C++14 (gcc 13.3.0 + boost 1.87.0) |
結果 |
AC
|
実行時間 | 3 ms / 5,000 ms |
コード長 | 866 bytes |
コンパイル時間 | 850 ms |
コンパイル使用メモリ | 75,388 KB |
実行使用メモリ | 5,248 KB |
最終ジャッジ日時 | 2024-10-11 02:11:21 |
合計ジャッジ時間 | 1,479 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 20 |
ソースコード
#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);}}if (cnt == 0) break;}cout << ret << endl;}return 0;}