結果

問題 No.3332 Consecutive Power Sum (Small)
コンテスト
ユーザー kokonotsu
提出日時 2025-11-02 22:46:42
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 836 bytes
コンパイル時間 278 ms
コンパイル使用メモリ 82,448 KB
実行使用メモリ 263,176 KB
最終ジャッジ日時 2025-11-02 22:47:05
合計ジャッジ時間 20,378 ms
ジャッジサーバーID
(参考情報)
judge5 / judge2
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 4 WA * 48
権限があれば一括ダウンロードができます

ソースコード

diff #

N = int(input())

C = 0
ans = []

for X in range(1, 2 * 10 ** 6):
    Y = 2 * N // X
    if X * Y == 2 * N:
        L = (X - Y + 1) // 2
        R = (X + Y - 1) // 2
        if 0 < L <= R and R > 0:
            C += 1
            ans.append((1, L, R))

for e in range(2, 40):
    d = {0:0}
    rev = {0:0}
    for i in range(1, 10 ** 6 + 1):
        p = pow(i, e)
        if p > N:
            break

        p = d[i-1] + pow(i, e)
        d[i] = p
        rev[p] = i

    for l in range(1, 10 ** 6 + 1):
        p = pow(l, e)
        if p > N:
            break
        elif p == N:
            C += 1
            ans.append((e, l, l))
            break
        else:
            x = N + d[l-1]

            if x in rev:
                C += 1
                ans.append((e, l, rev[x]))

print(C)
ans.sort()
for a in ans:
    print(*a)
0