結果
| 問題 |
No.1330 Multiply or Divide
|
| コンテスト | |
| ユーザー |
c-yan
|
| 提出日時 | 2021-01-10 00:46:19 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 120 ms / 2,000 ms |
| コード長 | 825 bytes |
| コンパイル時間 | 197 ms |
| コンパイル使用メモリ | 82,188 KB |
| 実行使用メモリ | 116,784 KB |
| 最終ジャッジ日時 | 2025-06-20 01:25:53 |
| 合計ジャッジ時間 | 4,915 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 51 |
ソースコード
from collections import deque
INF = 10 ** 20
N, M, P, *A = map(int, open(0).read().split())
def f(x):
c = 0
while x % P == 0:
c += 1
x //= P
return (x, c)
max_A = max(A)
if max_A > M:
print(1)
exit()
b = {}
for m, c in map(f, A):
b.setdefault(c, 0)
b[c] = max(b[c], m)
for k in list(b):
if b[k] == 1:
del b[k]
t = 1
for k in sorted(b):
if b[k] <= t:
del b[k]
else:
t = b[k]
cs = sorted(b)
if len(cs) == 0:
print(-1)
exit()
result = INF
q = deque([(0, 1)])
d = {}
d[0] = 1
while q:
c, x = q.popleft()
if x * max_A > M:
print(c + 1)
break
for k in cs:
d.setdefault(c + 1 + k, 0)
if x * b[k] > d[c + 1 + k]:
d[c + 1 + k] = x * b[k]
q.append((c + 1 + k, x * b[k]))
c-yan