結果

問題 No.3332 Consecutive Power Sum (Small)
コンテスト
ユーザー kidodesu
提出日時 2025-11-02 22:10:36
言語 PyPy3
(7.3.15)
結果
WA  
実行時間 -
コード長 1,002 bytes
コンパイル時間 298 ms
コンパイル使用メモリ 82,852 KB
実行使用メモリ 224,192 KB
最終ジャッジ日時 2025-11-02 22:10:49
合計ジャッジ時間 12,650 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 2
other AC * 34 WA * 18
権限があれば一括ダウンロードができます

ソースコード

diff #

n = int(input())
C = set()
for i in range(1, 10 ** 6+2):
    if i * i > n:
        break
    if n % i == 0:
        C.add(i)
        C.add(n // i)

C = list(C)
C.sort()
Ans = []

for a in C:
    b = n // a
    if not b % 2 and not a % 2:
        continue
    if not b % 2:
        k = a // 2
        k_ = k + 1
        l = k - b // 2 + 1
        r = k_ + b // 2 - 1
        if 1 <= l:
            Ans.append((1, l, r))
    else:
        l = a - b // 2
        r = a + b // 2
        if 1 <= l:
            Ans.append((1, l, r))
    if a % 2 and b % 2:
        k = a // 2
        k_ = k + 1
        l = k - b + 1
        r = k_ + b - 1
        if 1 <= l:
            Ans.append((1, l, r))
        


for i in range(2, 61):
    D = {0: 0}
    pre = 0
    r = 1
    while pow(r, i) <= n:
        now = pre + pow(r, i)
        if now - n in D:
            Ans.append((i, D[now-n]+1, r))
        D[now] = r
        pre = now
        r += 1

Ans.sort()
print(len(Ans))
for e, l, r in Ans:
    print(e, l, r)
0