結果
| 問題 | No.252 "良問"(良問とは言っていない (2) |
| コンテスト | |
| ユーザー |
tnoda_
|
| 提出日時 | 2015-08-31 15:16:20 |
| 言語 | PyPy2 (7.3.20) |
| 結果 |
AC
|
| 実行時間 | 348 ms / 2,000 ms |
| コード長 | 947 bytes |
| 記録 | |
| コンパイル時間 | 208 ms |
| コンパイル使用メモリ | 78,104 KB |
| 最終ジャッジ日時 | 2025-12-03 16:30:46 |
|
ジャッジサーバーID (参考情報) |
judge5 / judge2 |
| 純コード判定しない問題か言語 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 7 |
ソースコード
from sys import stdin
def solve(S):
L = len(S)
# Leading problems
lp = [0] * L
for i in xrange(L-6):
flag = True
lp[i+6] = lp[i+5]
for j in xrange(7):
if S[i+j] != "problem"[j]:
flag = False
if flag:
lp[i+6] += 1
# good cost at i
good = [4] * L
for i in xrange(L-10):
for j in xrange(4):
if S[i+j] == "good"[j]:
good[i] -= 1
# problem cost at i
problem = [7] * L
for i in xrange(L-6):
for j in xrange(7):
if S[i+j] == "problem"[j]:
problem[i] -= 1
for i in xrange(L-6, -1, -1):
problem[i] = min(problem[i+1], problem[i])
ans = good[0] + problem[4]
for i in xrange(1, L-10):
ans = min(ans, good[i] + problem[i+4] + lp[i-1])
print(ans)
lines = stdin.read().split('\n')
T = int(lines[0])
for i in xrange(T):
solve(lines[i+1])
tnoda_