結果

問題 No.3 ビットすごろく
ユーザー foumifoumi
提出日時 2019-04-07 08:45:54
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
WA  
実行時間 -
コード長 918 bytes
コンパイル時間 757 ms
コンパイル使用メモリ 11,004 KB
実行使用メモリ 8,028 KB
最終ジャッジ日時 2023-09-08 17:03:08
合計ジャッジ時間 2,620 ms
ジャッジサーバーID
(参考情報)
judge14 / judge12
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 15 ms
7,804 KB
testcase_01 AC 16 ms
8,004 KB
testcase_02 AC 15 ms
7,868 KB
testcase_03 AC 15 ms
7,864 KB
testcase_04 AC 16 ms
7,856 KB
testcase_05 AC 16 ms
7,764 KB
testcase_06 AC 16 ms
7,892 KB
testcase_07 AC 16 ms
8,000 KB
testcase_08 WA -
testcase_09 WA -
testcase_10 WA -
testcase_11 WA -
testcase_12 AC 16 ms
7,816 KB
testcase_13 AC 15 ms
7,840 KB
testcase_14 AC 16 ms
7,844 KB
testcase_15 AC 16 ms
7,824 KB
testcase_16 WA -
testcase_17 WA -
testcase_18 AC 15 ms
7,848 KB
testcase_19 WA -
testcase_20 WA -
testcase_21 AC 14 ms
8,024 KB
testcase_22 AC 16 ms
7,816 KB
testcase_23 AC 16 ms
7,980 KB
testcase_24 WA -
testcase_25 WA -
testcase_26 AC 15 ms
7,840 KB
testcase_27 WA -
testcase_28 WA -
testcase_29 WA -
testcase_30 WA -
testcase_31 AC 16 ms
7,816 KB
testcase_32 WA -
権限があれば一括ダウンロードができます

ソースコード

diff #

N = int(input())

def play():
    global count
    global current_location
    if current_location == N:
        print(current_location)
    else:
        for n in range(current_location, 10**5):
            move = bin(current_location).count('1')
            if current_location + move == N:
                count += 1
                print(count)
                break
            elif current_location + move < N:
                current_location += move
                map.append(n)
                count += 1
            elif current_location + move > N:
                current_location -= move
                if current_location in map:
                    print(-1)
                    break
                else:
                    map.append(n)
                    count += 1
                    switch()
                    break

def switch():
    play()

current_location = 1
count = 1
map = []

play()
0