結果
| 問題 |
No.462 6日知らずのコンピュータ
|
| コンテスト | |
| ユーザー |
suppy193
|
| 提出日時 | 2017-02-09 11:24:28 |
| 言語 | Ruby (3.4.1) |
| 結果 |
AC
|
| 実行時間 | 125 ms / 2,000 ms |
| コード長 | 778 bytes |
| コンパイル時間 | 380 ms |
| コンパイル使用メモリ | 7,424 KB |
| 実行使用メモリ | 12,544 KB |
| 最終ジャッジ日時 | 2024-12-26 18:11:14 |
| 合計ジャッジ時間 | 12,739 ms |
|
ジャッジサーバーID (参考情報) |
judge1 / judge2 |
(要ログイン)
| ファイルパターン | 結果 |
|---|---|
| sample | AC * 3 |
| other | AC * 84 |
コンパイルメッセージ
Syntax OK
ソースコード
n, k = gets.strip.split(' ').map(&:to_i)
if k == 0
a = []
else
a = gets.strip.split(' ').map(&:to_i)
end
def fact(n)
return 1 if n == 0 || n == 1
return n * fact(n - 1)
end
def permutation(n, k)
return fact(n) / fact(k)
end
b = a.sort{|x, y| x.to_s(2).count('1') <=> y.to_s(2).count('1')}
(0...b.length - 1).each do |i|
(0...b[i].to_s(2).length).each do |j|
if b[i].to_s(2)[-j - 1] == '1' && b[i + 1].to_s(2)[-j - 1] == '0'
p 0
exit
end
end
end
bit_num = []
a.each do |ai|
bit_num << ai.to_s(2).count('1')
end
if bit_num.length != bit_num.uniq.length
p 0
exit
end
bit_num += [0, n]
bit_num = bit_num.uniq
bit_num.sort!
ans = 1
(0...bit_num.length - 1).each do |i|
ans *= permutation(bit_num[i + 1] - bit_num[i], 1) % (10**9 + 7)
end
p ans % (10**9 + 7)
suppy193