結果

問題 No.3 ビットすごろく
ユーザー sue_charo
提出日時 2017-04-12 16:21:38
言語 Python3
(3.13.1 + numpy 2.2.1 + scipy 1.14.1)
結果
RE  
実行時間 -
コード長 610 bytes
コンパイル時間 70 ms
コンパイル使用メモリ 12,544 KB
実行使用メモリ 10,752 KB
最終ジャッジ日時 2024-07-18 10:22:01
合計ジャッジ時間 1,674 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other RE * 33
権限があれば一括ダウンロードができます

ソースコード

diff #

# coding: utf-8
import sys
sys.getrecursionlimit(10 ** 6)

N = int(input())


def search_move(num):
    count = 0
    for i in list(bin(num)):
        if i == "1":
            count += 1
    return count


if N == 1:
    print(1)
    quit()

memo = [0] * (N + 1)


def move(count=1, num=1):
    global memo
    if num == N:
        return count

    if num <= 0 or num > N:
        return -1
    else:
        if memo[num] == 1:
            return -1

        memo[num] = 1
        move_num = search_move(num)
        return max(move(count + 1, num - move_num), move(count + 1, num + move_num))

print(move())
0