結果
問題 | No.3 ビットすごろく |
ユーザー |
![]() |
提出日時 | 2018-06-16 16:59:53 |
言語 | Nim (2.2.0) |
結果 |
WA
|
実行時間 | - |
コード長 | 613 bytes |
コンパイル時間 | 3,397 ms |
コンパイル使用メモリ | 69,052 KB |
実行使用メモリ | 6,948 KB |
最終ジャッジ日時 | 2024-06-30 16:18:02 |
合計ジャッジ時間 | 14,210 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 18 WA * 15 |
コンパイルメッセージ
/home/judge/data/code/Main.nim(1, 28) Warning: imported and not used: 'sets' [UnusedImport] /home/judge/data/code/Main.nim(1, 18) Warning: imported and not used: 'sequtils' [UnusedImport]
ソースコード
import strutils, sequtils, sets, algorithm proc trfm(i: int): int = i.toBin(16).count('1') let N = stdin.readLine.parseInt var ttl, mini1, mini2 = newSeq[int](N) x = 1 mini1 = @[0] ttl[0] = 1 proc go(x: int) = for i0 in mini1.sorted(cmp, Descending): var i = i0 while true: let pre = i i += (i + 1).trfm * x if x == 1: if i >= N: break else: if i <= 0: break if ttl[i] == 0: ttl[i] = ttl[pre] + 1 mini2.add i if mini2.len == 0: echo -1; quit() swap(mini1, mini2) mini2 = @[] while ttl[^1] == 0: go(x) x *= -1 echo ttl[^1]