結果
問題 | No.1659 Product of Divisors |
ユーザー |
![]() |
提出日時 | 2021-08-29 12:31:47 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 854 bytes |
コンパイル時間 | 164 ms |
コンパイル使用メモリ | 82,432 KB |
実行使用メモリ | 92,288 KB |
最終ジャッジ日時 | 2024-11-22 04:54:52 |
合計ジャッジ時間 | 3,706 ms |
ジャッジサーバーID (参考情報) |
judge5 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 6 WA * 2 RE * 15 |
ソースコード
import mathdef factorize(n):d = {}temp = int(math.sqrt(n))+1for i in range(2, temp):while n%i== 0:n //= iif i in d:d[i] += 1else:d[i] = 1if d == {}:d[n] = 1else:if n in d:d[n] += 1elif n != 1:d[n] =1return dN = 10**6mod = 10**9+7fac = [1]*(N+1)finv = [1]*(N+1)for i in range(N):fac[i+1] = fac[i] * (i+1) % modfinv[-1] = pow(fac[-1], mod-2, mod)for i in reversed(range(N)):finv[i] = finv[i+1] * (i+1) % moddef cmb1(n, r, mod):if r <0 or r > n:return 0r = min(r, n-r)return fac[n] * finv[r] * finv[n-r] % modn, k = map(int, input().split())D = factorize(n)ans = 1for p, q in D.items():ans *= cmb1(q+k, k, mod)ans %= modprint(ans)