結果
問題 | No.1972 Modulo Set |
ユーザー |
![]() |
提出日時 | 2022-06-11 09:52:01 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 200 ms / 2,000 ms |
コード長 | 418 bytes |
コンパイル時間 | 150 ms |
コンパイル使用メモリ | 7,424 KB |
実行使用メモリ | 33,280 KB |
最終ジャッジ日時 | 2024-10-05 01:43:32 |
合計ジャッジ時間 | 6,039 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
sample | AC * 3 |
other | AC * 34 |
コンパイルメッセージ
Syntax OK
ソースコード
N, M = gets.split.map(&:to_i) A = gets.split.map(&:to_i) counter = A.map { |a| a % M }.tally counter.default = 0 ans = 0 checked = Hash.new(false) counter.each do |i, cnt| j = M - i next if checked[j] checked[i] = true checked[j] = true cnt_1 = ((i + i) % M == 0) ? [1, counter[i]].min : counter[i] cnt_2 = ((j + j) % M == 0) ? [1, counter[j]].min : counter[j] ans += [cnt_1, cnt_2].max end puts ans