結果
| 問題 |
No.1330 Multiply or Divide
|
| コンテスト | |
| ユーザー |
c-yan
|
| 提出日時 | 2021-01-10 00:53:30 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
AC
|
| 実行時間 | 119 ms / 2,000 ms |
| コード長 | 632 bytes |
| コンパイル時間 | 179 ms |
| コンパイル使用メモリ | 82,208 KB |
| 実行使用メモリ | 116,024 KB |
| 最終ジャッジ日時 | 2025-06-20 01:26:09 |
| 合計ジャッジ時間 | 5,153 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| 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)
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()
q = deque([(0, 1)])
while q:
c, x = q.popleft()
if x * max_A > M:
print(c + 1)
break
for k in cs:
q.append((c + 1 + k, x * b[k]))
c-yan