結果
| 問題 |
No.3 ビットすごろく
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2018-09-01 22:21:46 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
RE
|
| 実行時間 | - |
| コード長 | 557 bytes |
| コンパイル時間 | 85 ms |
| コンパイル使用メモリ | 12,544 KB |
| 実行使用メモリ | 11,392 KB |
| 最終ジャッジ日時 | 2024-09-21 17:59:37 |
| 合計ジャッジ時間 | 2,994 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge1 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 32 RE * 1 |
ソースコード
import queue
#移動するマス数を求める関数
def calcpop(num):
return bin(num).count("1")
N=int(input())
q=queue.Queue()
q.put(1)
masu =[]
masu=[0]*10000
masu[1]=1
while q.empty()==False:
curpos=q.get()
popcnt=calcpop(curpos)
if (curpos-popcnt>0 and masu[curpos-popcnt]==0):
masu[curpos-popcnt]=masu[curpos]+1
q.put(curpos-popcnt)
if (curpos+popcnt<=N and masu[curpos+popcnt]==0):
masu[curpos+popcnt]=masu[curpos]+1
q.put(curpos+popcnt)
if masu[N]==0:
print(-1)
else:
print(masu[N])