結果
問題 |
No.847 Divisors of Power
|
ユーザー |
|
提出日時 | 2024-05-12 16:52:59 |
言語 | PyPy3 (7.3.15) |
結果 |
AC
|
実行時間 | 117 ms / 2,000 ms |
コード長 | 744 bytes |
コンパイル時間 | 312 ms |
コンパイル使用メモリ | 82,572 KB |
実行使用メモリ | 76,872 KB |
最終ジャッジ日時 | 2024-12-20 09:10:23 |
合計ジャッジ時間 | 3,008 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge1 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 4 |
other | AC * 26 |
ソースコード
def prime_factors(N): res = {} for i in range(2, int(N ** 0.5) + 1): while N % i == 0: res.setdefault(i, 0) res[i] += 1 N //= i if N != 1: res[N] = 1 return res N, K, M = map(int, input().split()) N_pf = prime_factors(N) NK_pf = [] for p, q in N_pf.items(): NK_pf.append((p, q * K)) import sys sys.setrecursionlimit(10 ** 7) def dfs(product, idx): global ans if idx == L: if product <= M: ans += 1 return for i in range(NK_pf[idx][1] + 1): if product * pow(NK_pf[idx][0], i) <= M: dfs(product * pow(NK_pf[idx][0], i), idx + 1) else: break L = len(NK_pf) ans = 0 dfs(1, 0) print(ans)