結果
| 問題 |
No.1330 Multiply or Divide
|
| コンテスト | |
| ユーザー |
c-yan
|
| 提出日時 | 2021-01-10 01:03:03 |
| 言語 | Python3 (3.13.1 + numpy 2.2.1 + scipy 1.14.1) |
| 結果 |
AC
|
| 実行時間 | 517 ms / 2,000 ms |
| コード長 | 800 bytes |
| コンパイル時間 | 244 ms |
| コンパイル使用メモリ | 12,160 KB |
| 実行使用メモリ | 32,340 KB |
| 最終ジャッジ日時 | 2025-06-20 01:26:18 |
| 合計ジャッジ時間 | 5,982 ms |
|
ジャッジサーバーID (参考情報) |
judge4 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 51 |
ソースコード
from heapq import heappop, heappush
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)
t = 1
for k in sorted(b):
if b[k] <= t:
del b[k]
else:
t = b[k]
if len(b) == 0:
print(-1)
exit()
q = [(0, 1)]
max_x = {}
max_x[0] = 1
while q:
c, x = heappop(q)
if max_x[c] > x:
continue
if x * max_A > M:
print(c + 1)
break
for k in b:
nc = c + 1 + k
nx = x * b[k]
max_x.setdefault(nc, 0)
if nx > max_x[nc]:
max_x[nc] = nx
heappush(q, (nc, nx))
c-yan