結果
| 問題 |
No.3 ビットすごろく
|
| コンテスト | |
| ユーザー |
papinnie
|
| 提出日時 | 2019-08-06 20:05:02 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 763 bytes |
| コンパイル時間 | 148 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 11,392 KB |
| 最終ジャッジ日時 | 2024-07-18 14:20:01 |
| 合計ジャッジ時間 | 4,075 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 11 WA * 5 RE * 17 |
ソースコード
N = int(input())
def get_total(x):
return sum(map(int,list("{0:b}".format(x))))
already = 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
print(mv_count)
exit(0)
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)
# 到達できなかった
print(-1)
papinnie