回答:
組み込み済み:
[1,2,3,4].shuffle => [2, 1, 3, 4]
[1,2,3,4].shuffle => [1, 3, 2, 4]
!
は、シャッフルの呼び出しの後にa を追加します。!
シャッフルされていない配列が返され、割り当ての準備ができています。
Ruby 1.8.6の場合(シャッフルが組み込まれていない):
array.sort_by { rand }
sort_by
関数は、計算された数値が0未満、0、または0より大きいかどうかにのみ注意を払う、JavaScriptのソート関数(またはその点ではルビーのソート関数)のように機能しないことに注意してください。代わりにsort_by
、各アイテムの計算値を記憶し、その値でアイテムを並べ替えます。したがって、この場合、各アイテムには乱数が割り当てられ、配列はそれらの乱数でソートされます。
Array for Ruby 1.8.6のバックポートGemからのコード。Ruby 1.8.7以降が組み込まれています。
class Array
# Standard in Ruby 1.8.7+. See official documentation[http://ruby-doc.org/core-1.9/classes/Array.html]
def shuffle
dup.shuffle!
end unless method_defined? :shuffle
# Standard in Ruby 1.8.7+. See official documentation[http://ruby-doc.org/core-1.9/classes/Array.html]
def shuffle!
size.times do |i|
r = i + Kernel.rand(size - i)
self[i], self[r] = self[r], self[i]
end
self
end unless method_defined? :shuffle!
end