結果
| 問題 | No.14 最小公倍数ソート |
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2014-12-31 13:14:42 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 554 ms / 5,000 ms |
| コード長 | 377 bytes |
| コンパイル時間 | 321 ms |
| コンパイル使用メモリ | 7,552 KB |
| 実行使用メモリ | 16,128 KB |
| 最終ジャッジ日時 | 2024-12-26 14:41:24 |
| 合計ジャッジ時間 | 8,362 ms |
|
ジャッジサーバーID (参考情報) |
judge2 / judge4 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| other | AC * 20 |
コンパイルメッセージ
Syntax OK
ソースコード
require'prime'
N=gets.to_i
a=gets.split.map(&:to_i)
div=Hash.new{|h,x|
h[x]=x.prime_division.inject([1]){|s,(p,k)|
s+s.flat_map{|i|(1..k).map{|j|i*p**j}}
}
}
mul=(0..a.max).map{[]}
a.sort.each{|i|
div[i].each{|d|
mul[d] << i
}
}
puts ([i=a[0]]+(2..N).map{
i=div[i].map{|d|
mul[d].delete_at(mul[d].index i)
(t=mul[d][0])?[t/d,t]:[1e9]
}.min[1]
})*" "