結果
| 問題 | No.252 "良問"(良問とは言っていない (2) | 
| コンテスト | |
| ユーザー |  convexineq | 
| 提出日時 | 2020-12-11 06:40:58 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 910 ms / 2,000 ms | 
| コード長 | 572 bytes | 
| コンパイル時間 | 219 ms | 
| コンパイル使用メモリ | 82,500 KB | 
| 実行使用メモリ | 101,940 KB | 
| 最終ジャッジ日時 | 2024-09-19 21:07:50 | 
| 合計ジャッジ時間 | 6,695 ms | 
| ジャッジサーバーID (参考情報) | judge3 / judge2 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 7 | 
ソースコード
def solve(s):
    n = len(s)
    g = [11]*(n-3)
    p = [11]*(n-6)
    for i in range(n-3):
        g[i] = sum(x != y for x,y in zip("good",s[i:i+4]))
    for i in range(n-6):
        p[i] = sum(x != y for x,y in zip("problem",s[i:i+7]))
    q = [1 if pi == 0 else 0 for pi in p]
    for i in range(1,n-6):
        q[i] += q[i-1]
    for i in range(n-8,-1,-1):
        p[i] = min(p[i],p[i+1])
    ans = 11
    for i in range(n-10):
        ans = min(ans,g[i]+p[i+4] + (q[i-7] if i >= 7 else 0))
    return ans
T = int(input())
for _ in range(T):
    print(solve(input()))
            
            
            
        