結果
問題 | No.462 6日知らずのコンピュータ |
ユーザー |
![]() |
提出日時 | 2017-02-10 08:47:16 |
言語 | Ruby (3.4.1) |
結果 |
AC
|
実行時間 | 98 ms / 2,000 ms |
コード長 | 778 bytes |
コンパイル時間 | 93 ms |
コンパイル使用メモリ | 7,296 KB |
実行使用メモリ | 12,544 KB |
最終ジャッジ日時 | 2024-12-26 14:22:32 |
合計ジャッジ時間 | 9,842 ms |
ジャッジサーバーID (参考情報) |
judge3 / judge4 |
(要ログイン)
ファイルパターン | 結果 |
---|---|
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)