結果
| 問題 | No.1330 Multiply or Divide |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2025-01-20 20:46:40 |
| 言語 | PyPy3 (7.3.15) |
| 結果 |
WA
|
| 実行時間 | - |
| コード長 | 832 bytes |
| 記録 | |
| コンパイル時間 | 910 ms |
| コンパイル使用メモリ | 82,688 KB |
| 実行使用メモリ | 119,692 KB |
| 最終ジャッジ日時 | 2025-01-20 20:46:51 |
| 合計ジャッジ時間 | 6,382 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge3 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 45 WA * 1 |
ソースコード
## https://yukicoder.me/problems/no/944
import heapq
def main():
N, M, P = map(int, input().split())
A = list(map(int, input().split()))
A.sort(reverse=True)
p_array = []
for i in range(N):
a = A[i]
p_cnt = 0
while a % P == 0:
a //= P
p_cnt += 1
p_array.append((a, p_cnt))
answer = float("inf")
for a, p_cnt in p_array:
ans = 0
x = 1
is_ok = True
while x * A[0] <= M:
if a > 1:
x *= a
ans += p_cnt + 1
else:
is_ok = False
break
if is_ok:
answer = min(ans + 1, answer)
if answer == float("inf"):
print(-1)
else:
print(answer)
if __name__ == "__main__":
main()