結果

問題 No.3549 SigMax Digits (Judge ver.)
コンテスト
ユーザー LyricalMaestro
提出日時 2026-05-24 02:57:29
言語 PyPy3
(7.3.17)
コンパイル:
pypy3 -mpy_compile _filename_
実行:
pypy3 _filename_
結果
AC  
実行時間 2,186 ms / 3,000 ms
コード長 1,271 bytes
記録
記録タグの例:
初AC ショートコード 純ショートコード 純主流ショートコード 最速実行時間
コンパイル時間 174 ms
コンパイル使用メモリ 85,128 KB
実行使用メモリ 90,112 KB
最終ジャッジ日時 2026-05-24 02:57:42
合計ジャッジ時間 11,548 ms
ジャッジサーバーID
(参考情報)
judge3_1 / judge2_1
純コード判定待ち
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 1
other AC * 7
権限があれば一括ダウンロードができます

ソースコード

diff #
raw source code

# https://yukicoder.me/problems/no/3549

from collections import deque


def solve2(R):
    r_str = str(R)
    r_len = len(r_str)

    max_pre_digit = 0
    answer = 0
    for i in range(r_len):
        r = int(r_str[i])

        if i < r_len - 1:
            l0 = r_len - 1 - i
            for l in range(r):
                rate = 1
                value = max(max_pre_digit, l, 0)
                answer += rate * value

                for k in range(1, 10):
                    rate = (k + 1) ** l0 - k ** l0
                    value = max(max_pre_digit, l, k)
                    answer += rate * value
        else:
            for l in range(r + 1):
                value = max(max_pre_digit, l)
                answer += value
            
        max_pre_digit = max(max_pre_digit, r)
    return answer




    l = r_len - 1
    if l > 0:
        for k in range(1, 10):

            answer += (k + 1)



def solve(L, R):

    ans1 = solve2(R)
    if L > 0:
        ans1 -= solve2(L - 1)
    return ans1


def main():
    T = int(input())
    answers = []
    for _ in range(T):
        L, R = map(int ,input().split())
        ans = solve(L, R)
        answers.append(ans)

    for ans in answers:
        print(ans)






if __name__ == "__main__":
    main()
0