結果
| 問題 | No.3 ビットすごろく | 
| コンテスト | |
| ユーザー |  | 
| 提出日時 | 2021-03-07 10:26:30 | 
| 言語 | PyPy3 (7.3.15) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 86 ms / 5,000 ms | 
| コード長 | 563 bytes | 
| コンパイル時間 | 295 ms | 
| コンパイル使用メモリ | 81,792 KB | 
| 実行使用メモリ | 76,544 KB | 
| 最終ジャッジ日時 | 2024-10-08 23:07:13 | 
| 合計ジャッジ時間 | 3,659 ms | 
| ジャッジサーバーID (参考情報) | judge4 / judge3 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| other | AC * 33 | 
ソースコード
N=int(input())
dp=[float("inf")]*(N+1)
dp[1]=1;dp[0]=-1
from collections import deque
q=deque([1])
while q:
    i=q.popleft()
    if dp[i]>=1:
        a=str(bin(i))
        a=a.count("1")
        try:
            if dp[i+a]==float("inf"):
                q.append(i+a)
            dp[i+a]=min(dp[i]+1,dp[i+a])
        except IndexError:
            pass
        try:
            if dp[i-a]==float("inf"):
                q.append(i-a)
            dp[i-a]=min(dp[i]+1,dp[i-a])
        except IndexError:
            pass
print(dp[N] if dp[N]!=float("inf") else -1)
            
            
            
        