結果

問題 No.3 ビットすごろく
ユーザー calei
提出日時 2019-12-29 09:55:18
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
AC  
実行時間 36 ms / 5,000 ms
コード長 552 bytes
コンパイル時間 84 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 11,264 KB
最終ジャッジ日時 2024-07-01 09:36:27
合計ジャッジ時間 2,121 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

# 2019/12/29
# BFS

from collections import deque

n=int(input())


def bfs(s,g):
    visited=[False]*(n+1)
    d=[-1]*(n+1)
    d[s]=1
    visited[0]=True
    visited[s]=True
    que=deque()
    que.append(s)

    while que:
        u=que.popleft()
        step=bin(u).count('1')
        nxt=u+step
        prv=u-step

        for v in [nxt,prv]:
            if v>n:continue
            if visited[v]:continue
            visited[v]=True
            d[v]=d[u]+1
            que.append(v)
            
        

    return d

res=bfs(1,n)
print(res[n])
0