結果

問題 No.915 Plus Or Multiple Operation
ユーザー ningenMeningenMe
提出日時 2019-10-12 19:23:23
言語 Python3
(3.12.2 + numpy 1.26.4 + scipy 1.12.0)
結果
AC  
実行時間 30 ms / 2,000 ms
コード長 475 bytes
コンパイル時間 291 ms
コンパイル使用メモリ 12,672 KB
実行使用メモリ 10,752 KB
最終ジャッジ日時 2024-04-24 18:30:32
合計ジャッジ時間 1,348 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 29 ms
10,752 KB
testcase_01 AC 30 ms
10,752 KB
testcase_02 AC 28 ms
10,752 KB
testcase_03 AC 29 ms
10,752 KB
testcase_04 AC 28 ms
10,752 KB
testcase_05 AC 29 ms
10,752 KB
testcase_06 AC 28 ms
10,752 KB
testcase_07 AC 27 ms
10,752 KB
testcase_08 AC 28 ms
10,624 KB
testcase_09 AC 27 ms
10,752 KB
testcase_10 AC 28 ms
10,624 KB
testcase_11 AC 29 ms
10,752 KB
testcase_12 AC 30 ms
10,624 KB
権限があれば一括ダウンロードができます

ソースコード

diff #

Q = int(input())
for q in range(Q):
    A,B,C = map(int,input().split())
    if C==1:
        print(-1)
        continue
    if A < C:
        print(B)
        continue

    bit = []
    while A>0:
        bit.append(A%C)
        A //= C
    bit.reverse()
    M = len(bit)
    sum = 0
    if bit[1]==0 or bit[0]*C+bit[1]<=2*C-2:
        sum += 2
    else :
        sum += 3
    for i in range(2,M):
        if(bit[i]>0) :
            sum += 1
    sum += M-2
    print(sum*B)
0