結果
| 問題 | No.1330 Multiply or Divide |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2026-05-18 01:47:31 |
| 言語 | PyPy3 (7.3.17) |
| 結果 |
AC
|
| 実行時間 | 153 ms / 2,000 ms |
| コード長 | 610 bytes |
| 記録 | |
| コンパイル時間 | 222 ms |
| コンパイル使用メモリ | 85,760 KB |
| 実行使用メモリ | 137,984 KB |
| 最終ジャッジ日時 | 2026-05-18 01:47:42 |
| 合計ジャッジ時間 | 7,591 ms |
|
ジャッジサーバーID (参考情報) |
judge2_0 / judge3_1 |
| 純コード判定待ち |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 51 |
ソースコード
def aa(s):
global m,c
if s>m:
return 0
if s*c>m:
v[s]=1
return 1
if s in v:
return v[s]
res=1<<30
for i in range(1,len(y)):
if y[i]:
res=min(res,aa(s*y[i])+i)
v[s]=res
return res
n,m,p=map(int,input().split())
a=list(map(int,input().split()))
x={};c=max(a)
if m<c:
print(1);exit()
for i in a:
d=1
while i%p==0:
i//=p;d+=1
if i==1:
continue
if i in x:
x[i]=min(x[i],d)
else:
x[i]=d
if len(x)==0:
print(-1)
exit()
y=[0]*61
for i,j in x.items():
y[j]=max(y[j],i)
v={}
print(aa(1))