結果

問題 No.120 傾向と対策:門松列(その1)
ユーザー 小指が強い人
提出日時 2015-11-15 19:59:14
言語 Ruby
(3.4.1)
結果
AC  
実行時間 833 ms / 5,000 ms
コード長 653 bytes
コンパイル時間 137 ms
コンパイル使用メモリ 7,424 KB
実行使用メモリ 13,568 KB
最終ジャッジ日時 2024-09-13 15:12:43
合計ジャッジ時間 3,471 ms
ジャッジサーバーID
(参考情報)
judge3 / judge4
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
other AC * 4
権限があれば一括ダウンロードができます
コンパイルメッセージ
Syntax OK

ソースコード

diff #

t = gets.to_i
t.times do 
    n = gets.to_i
    a = gets.split.map(&:to_i)
    h1 = Hash.new(0)
    n.times do |i|
        h1[a[i]] += 1
    end
    res = 0
    count = 0
    h1 = h1.sort_by{ |key, val| -val}
    while true do
        count = 0
        find = false
        h1.length.times do |k|
            if h1[k][1] <= 0
                next
            end
            h1[k][1] -= 1
            count += 1
            if count >= 3
                res += 1
                find = true
                break
            end
        end
        h1.sort!{ |a, b| b[1] <=> a[1] }
        if !find
            break
        end
    end
    puts res
end
0