結果
問題 | No.2249 GCDistance |
ユーザー |
![]() |
提出日時 | 2023-03-17 22:35:59 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 1,538 ms / 5,000 ms |
コード長 | 588 bytes |
コンパイル時間 | 129 ms |
コンパイル使用メモリ | 82,308 KB |
実行使用メモリ | 232,516 KB |
最終ジャッジ日時 | 2024-09-18 11:43:07 |
合計ジャッジ時間 | 19,307 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 10 |
ソースコード
import sys readline = sys.stdin.readline def euler_phi(N): euler = [i for i in range(N + 1)] for i in range(2, N + 1): if euler[i] == i: for j in range(i, N + 1, i): euler[j] = euler[j] // i * (i - 1) for i in range(2, N + 1): euler[i] = i - euler[i] - 1 euler[1] = 0 return euler T = int(readline()) MAX_N = 10 ** 7 + 5 L = euler_phi(MAX_N) Ac = [0] * MAX_N for i in range(MAX_N-1): Ac[i + 1] = Ac[i] + L[i + 1] for _ in range(T): N = int(readline()) print(Ac[N] + N * (N - 1)//2)