結果
問題 |
No.1611 Minimum Multiple with Double Divisors
|
ユーザー |
![]() |
提出日時 | 2025-07-21 21:40:28 |
言語 | PyPy3 (7.3.15) |
結果 |
WA
|
実行時間 | - |
コード長 | 568 bytes |
コンパイル時間 | 420 ms |
コンパイル使用メモリ | 82,968 KB |
実行使用メモリ | 77,704 KB |
最終ジャッジ日時 | 2025-07-21 21:40:42 |
合計ジャッジ時間 | 12,291 ms |
ジャッジサーバーID (参考情報) |
judge4 / judge5 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 2 |
other | AC * 9 WA * 28 |
ソースコード
def f(x, p): res = 0 while x % p == 0: x //= p res += 1 return res def solve(): X = int(input()) if X == 1: return 2 ps = [2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31] res = INF for p in ps: if X % p != 0: res = min(res, X * p) break for p in ps: cnt = f(X, p) if cnt == 0: continue x = X // pow(p, cnt) * pow(p, cnt+cnt+1) res = min(res, x) return res INF = 1 << 60 T = int(input()) for _ in range(T): ans = solve() print(ans)