結果

問題 No.120 傾向と対策:門松列(その1)
ユーザー 小指が強い人小指が強い人
提出日時 2015-11-15 19:59:14
言語 Ruby
(3.3.0)
結果
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
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 450 ms
13,568 KB
testcase_01 AC 833 ms
13,312 KB
testcase_02 AC 321 ms
13,440 KB
testcase_03 AC 825 ms
13,568 KB
権限があれば一括ダウンロードができます
コンパイルメッセージ
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