結果
| 問題 |
No.3 ビットすごろく
|
| コンテスト | |
| ユーザー |
papinnie
|
| 提出日時 | 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)
papinnie