結果
問題 | No.3 ビットすごろく |
ユーザー | wonda_t_coffee |
提出日時 | 2020-01-27 23:24:50 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 98 ms / 5,000 ms |
コード長 | 373 bytes |
コンパイル時間 | 34 ms |
コンパイル使用メモリ | 7,552 KB |
実行使用メモリ | 12,672 KB |
最終ジャッジ日時 | 2024-07-01 09:37:35 |
合計ジャッジ時間 | 4,123 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 33 |
コンパイルメッセージ
Syntax OK
ソースコード
n = gets.chomp.to_i max = 0xffffffff mins = [max]*(n+1) mins[1] = 1 q = [[1, 1]] until q.empty? i, c = q.shift m = i.to_s(2).count('1') if i - m > 0 && c + 1 < mins[i - m] q.push([i - m, c + 1]) mins[i - m] = c + 1 end if i + m <= n && c + 1 < mins[i + m] q.push([i + m, c + 1]) mins[i + m] = c + 1 end end puts mins[n] >= max ? -1 : mins[n]