結果
問題 |
No.3 ビットすごろく
|
ユーザー |
![]() |
提出日時 | 2019-08-06 20:14:53 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
WA
|
実行時間 | - |
コード長 | 878 bytes |
コンパイル時間 | 243 ms |
コンパイル使用メモリ | 12,416 KB |
実行使用メモリ | 17,280 KB |
最終ジャッジ日時 | 2024-07-18 14:22:54 |
合計ジャッジ時間 | 33,380 ms |
ジャッジサーバーID (参考情報) |
judge1 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 6 WA * 7 TLE * 3 -- * 17 |
ソースコード
import sys sys.setrecursionlimit(10000) N = int(input()) def get_total(x): return sum(map(int,list("{0:b}".format(x)))) already = set() ables = set() def go_next(now, mv_count): already.add(now) mv_count += 1 step = get_total(now) # 進める数 #print("now", now, "mv_count", mv_count, "step", step) go_m = now + step # 進む先 if go_m == N: # goal ables.add(mv_count) if go_m < N: go_next(go_m, mv_count) back_m = now - step # 戻る先 if back_m not in already: # 行ったことのあるところなら行かない if back_m > 0: go_next(back_m, mv_count) if N == 1: print(1) else: # 今=1, ステップ=1で再帰スタート go_next(1, 1) if len(ables) > 0: print(ables) print(min(ables)) else: # 到達できなかった print(-1)