結果
問題 | No.150 "良問"(良問とは言っていない |
ユーザー | tnoda_ |
提出日時 | 2015-03-21 22:58:57 |
言語 | Go (1.23.4) |
結果 |
AC
|
実行時間 | 11 ms / 5,000 ms |
コード長 | 987 bytes |
コンパイル時間 | 12,968 ms |
コンパイル使用メモリ | 238,736 KB |
実行使用メモリ | 6,820 KB |
最終ジャッジ日時 | 2024-10-11 01:54:09 |
合計ジャッジ時間 | 13,121 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 20 |
ソースコード
package main import ( "fmt" ) var good, problem, inf = []rune("good"), []rune("problem"), 1 << 28 func readS() []rune { var s string fmt.Scan(&s) a := make([]rune, len(s)) for i, r := range s { a[i] = r } return a } func hd(s0 []rune, offset int, s1 []rune) (z int) { for i, r := range s1 { if r != s0[i+offset] { z++ } } return } func min(x, y int) int { if y < x { return y } return x } func solve() { a := readS() N := len(a) g, p := make([]int, N), make([]int, N) for i := 0; i < N; i++ { g[i], p[i] = inf, inf } for i := 0; i < N-len(good); i++ { g[i] = hd(a, i, good) if i > 0 { g[i] = min(g[i], g[i-1]) } } for i := N - len(problem); i >= 0; i-- { p[i] = hd(a, i, problem) if i > N-len(problem)-1 { p[i] = min(p[i], p[i+1]) } } res := inf for i := 0; i < N-len(problem); i++ { res = min(res, g[i]+p[i+len(good)]) } fmt.Println(res) } func main() { var T int fmt.Scan(&T) for i := 0; i < T; i++ { solve() } }