結果

問題 No.368 LCM of K-products
コンテスト
ユーザー とりゐ
提出日時 2021-10-29 14:03:47
言語 PyPy3
(7.3.15)
結果
AC  
実行時間 481 ms / 2,000 ms
コード長 623 bytes
コンパイル時間 352 ms
コンパイル使用メモリ 82,432 KB
実行使用メモリ 77,440 KB
最終ジャッジ日時 2024-10-07 08:32:58
合計ジャッジ時間 7,306 ms
ジャッジサーバーID
(参考情報)
judge2 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 35
権限があれば一括ダウンロードができます

ソースコード

diff #

def fact(n):
  #fact(18)=[[2, 1],[3, 2]] (18 = 2**1 * 3**2)
  arr = []
  temp = n
  for i in range(2, int(-(-n**0.5//1))+1):
    if temp%i==0:
      cnt=0
      while temp%i==0:
        cnt+=1
        temp //= i
      arr.append([i, cnt])
  if temp!=1:
    arr.append([temp, 1])
  if arr==[]:
    arr.append([n, 1])
  return arr

from collections import defaultdict
n,k=map(int,input().split())
a=list(map(int,input().split()))
d=defaultdict(list)
for i in a:
  for p,m in fact(i):
    d[p].append(m)
mod=10**9+7
ans=1
for i in d:
  x=sorted(d[i],reverse=True)
  ans*=pow(i,sum(x[:min(len(x),k)]),mod)
  ans%=mod
print(ans)
0