結果
問題 |
No.3 ビットすごろく
|
ユーザー |
![]() |
提出日時 | 2020-11-02 06:55:20 |
言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
結果 |
AC
|
実行時間 | 68 ms / 5,000 ms |
コード長 | 955 bytes |
コンパイル時間 | 88 ms |
コンパイル使用メモリ | 12,544 KB |
実行使用メモリ | 12,672 KB |
最終ジャッジ日時 | 2024-07-01 09:59:17 |
合計ジャッジ時間 | 2,860 ms |
ジャッジサーバーID (参考情報) |
judge2 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
other | AC * 33 |
ソースコード
import bisect import heapq import itertools import sys import math import random import time from collections import Counter, deque, defaultdict from functools import reduce from operator import xor from typing import List mod = 10 ** 9 + 7 sys.setrecursionlimit(10 ** 9) def lmi(): return list(map(int, input().split())) def main(): N = int(input()) queue = deque() queue.append((1, 1)) visited = set() while queue: cur, depth = queue.popleft() if cur < 0 or N + 1 <= cur: continue if cur in visited: continue if cur == N: print(depth) return visited.add(cur) queue.append((cur + f(cur), depth + 1)) queue.append((cur - f(cur), depth + 1)) print(-1) def f(num): ret = 0 while num: if num % 2 == 1: ret += 1 num >>= 1 return ret if __name__ == '__main__': main()