結果
問題 | No.1966 Median of Divisors |
ユーザー | lilictaka |
提出日時 | 2022-06-03 22:36:53 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 387 ms / 2,000 ms |
コード長 | 390 bytes |
コンパイル時間 | 309 ms |
コンパイル使用メモリ | 81,920 KB |
実行使用メモリ | 83,044 KB |
最終ジャッジ日時 | 2024-09-21 03:02:06 |
合計ジャッジ時間 | 4,077 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 1 |
other | AC * 12 |
ソースコード
T = int(input()) mod = 10 ** 9 + 7 inv2 = pow(2,mod-2,mod) inv6 = pow(6,mod-2,mod) def sum2(st,goal,n): return ((st + goal) * n) % mod * inv2 def sum3(n): return (n * (n+1) * (2 * n + 1)) % mod * inv6 ANS = [] for _ in range(T): N,M = map(int,input().split()) ans = sum2(1,pow(N,M,mod),pow(N,M,mod)) - sum3(pow(N,M//2,mod)) ANS.append(ans%mod) print(*ANS,sep='\n')