結果
| 問題 | 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
ソースコード
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
            
            
            
        