結果

問題 No.241 出席番号(1)
ユーザー kazasiki
提出日時 2015-07-29 08:47:35
言語 Ruby
(3.4.1)
結果
AC  
実行時間 89 ms / 2,000 ms
コード長 763 bytes
コンパイル時間 298 ms
コンパイル使用メモリ 7,296 KB
実行使用メモリ 12,288 KB
最終ジャッジ日時 2024-11-30 21:31:58
合計ジャッジ時間 4,378 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample AC * 3
other AC * 29
権限があれば一括ダウンロードができます
コンパイルメッセージ
Main.rb:40: warning: ambiguous first argument; put parentheses or a space even after `-' operator
Syntax OK

ソースコード

diff #

class RandomNums
  def self.generate size
    dec_nums (0...size).map{|i| rand(0...(size-i))}
  end

  private

  def self.dec_nums nums
    array = (0...nums.size).to_a
    nums.map{|i| array.delete_at(i)}
  end
end

# input
N = gets.to_i
A = N.times.map{
      gets.to_i
    }

def check_nums nums
  nums.each.with_index{|num, i|
    return i if nums[i] == A[i]
  }
  return nil
end

def change_nums nums, index
  indexs = (0...nums.size).to_a
  indexs.delete(index)
  i = indexs.sample
  nums[index], nums[i] = nums[i], nums[index]
end

def check_A
  A.each{|i| return false if i >= N}
  A.uniq.size == 1
end

if check_A
  p -1
else
  nums = RandomNums.generate N
  while (ng = check_nums(nums)) != nil
    change_nums nums, ng
  end
  nums.each{|i| p i }
end
0