結果

問題 No.3549 SigMax Digits (Judge ver.)
コンテスト
ユーザー 👑 loop0919
提出日時 2026-04-22 19:44:54
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
AC  
実行時間 2,409 ms / 3,000 ms
コード長 705 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 285 ms
コンパイル使用メモリ 85,696 KB
実行使用メモリ 83,712 KB
最終ジャッジ日時 2026-05-22 21:46:40
合計ジャッジ時間 12,298 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge1_0
純コード判定待ち
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 7
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

LIMIT = 18


def answer(n: int) -> int:
    ans = 9 * n

    for d in range(1, 9):
        digits = [(n // 10**i) % 10 for i in range(LIMIT)]
        is_upper = False
        for i in range(LIMIT - 1, -1, -1):
            if d < digits[i] or is_upper:
                digits[i] = d
                is_upper = True

        # v := n 以下の正整数のうち、d 以下の数字のみで構成されるものの個数
        v = sum([digits[i] * (d + 1) ** i for i in range(LIMIT)])
        ans -= v

    return ans


def solve():
    L, R = [int(s) for s in input().split()]
    print(answer(R) - answer(L - 1))


if __name__ == "__main__":
    T = int(input())

    for _ in range(T):
        solve()
0