結果
| 問題 |
No.3331 Consecutive Cubic Sum
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-08-17 01:12:26 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 1,043 ms / 5,000 ms |
| コード長 | 721 bytes |
| コンパイル時間 | 393 ms |
| コンパイル使用メモリ | 82,232 KB |
| 実行使用メモリ | 312,620 KB |
| 最終ジャッジ日時 | 2025-11-02 20:50:24 |
| 合計ジャッジ時間 | 23,250 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 47 |
ソースコード
#! /usr/bin/env python
# dict
def solve(n: int):
cube = []
for i in range(n + 1):
if i * i * i <= n:
cube.append(i * i * i)
else:
break
# cube[i] = i**3
c = len(cube)
acc = [0] * (c + 1)
for i in range(c):
acc[i + 1] = acc[i] + cube[i]
# acc[i] = sum(j**3 for j < i)
# acc[i + 1] = sum(j**3 for j <= i)
right = {acc[i + 1]: i for i in range(1, c)}
ans = []
for l in range(1, c + 1):
r = right.get(acc[l] + n, -1)
if r != -1:
ans.append((l, r))
ans.sort()
return ans
if __name__ == "__main__":
n = int(input())
ans = solve(n)
print(len(ans))
for t in ans:
print(*t)