結果
| 問題 |
No.79 過小評価ダメ・ゼッタイ
|
| コンテスト | |
| ユーザー |
|
| 提出日時 | 2023-08-04 18:03:55 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 139 ms / 5,000 ms |
| コード長 | 627 bytes |
| コンパイル時間 | 73 ms |
| コンパイル使用メモリ | 7,296 KB |
| 実行使用メモリ | 19,456 KB |
| 最終ジャッジ日時 | 2024-10-14 15:13:45 |
| 合計ジャッジ時間 | 4,260 ms |
|
ジャッジサーバーID (参考情報) |
judge3 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 22 |
コンパイルメッセージ
Syntax OK
ソースコード
N = gets.chomp.to_i
Ls = gets.chomp.split.map(&:to_i) # => [1, 2, 3, 4, 1,]
counts = Ls.uniq.map{|item| [item, Ls.count(item)]}.to_h # => {1=>2, 2=>1, 3=>1, 4=>1}
# 任意の値が2個以上あるか確認する
values = counts.values # => [2, 1, 1, 1] 値のみを取り出す
# 最も大きい値が配列の中に1つしかない場合、キーを参照しputする
# 最もおきい値が2個以上の場合、あればキーを参照し、キーの数値が大きい方をputする
if values.count(values.max) == 1
puts counts.key(values.max)
else
puts counts.select { |k,value| value == values.max }.keys.max
end