繁体   English   中英

Ruby:使用`.each`或`.step`,为每次迭代前移随机量

[英]Ruby: using `.each` or `.step`, step forward a random amount for each iteration

(也对其他类似的非Rails方法开放)

给定(0..99) ,返回按顺序随机选择的条目。

结果示例:

0, 5, 11, 13, 34..

3, 12, 45, 67, 87

0, 1, 2, 3, 4, 5.. (当然不太可能)

目前的想法:

(0..99).step(rand(0..99)).each do |subindex|
  array.push(subindex)
end

但是,这为所有步骤设置了一个随机值,而我正在寻找每个步骤都是随机的。

获取要选择的元素数量的随机值,随机获取此元素数量,进行排序。

(0..99).to_a.sample((0..99).to_a.sample).sort
#⇒ [7, 20, 22, 29, 45, 48, 57, 61, 62, 76, 80, 82]

或者,更短一些(归功于@Stefan):

(0..99).to_a.sample(rand(0..99)).sort
#⇒ [7, 20, 22, 29, 45, 48, 57, 61, 62, 76, 80, 82]

或者,以更实用的方式:

λ = (0..99).to_a.method(:sample)
λ.(λ.()).sort

要精确输入N数字:

N = 10
(0..99).to_a.sample(N).sort
#⇒ [1, 5, 8, 12, 45, 54, 60, 65, 71, 91]

有很多方法可以实现它。

例如,这是一个缓慢而又简单的例子:

# given `array`
random_indexes = (0...array.size).to_a.sample(rand(array.size))
random_indexes.sort.each { |i| puts array[i] }

或者为什么不只是:

array.each do |value|
  next if rand(2).zero?
  puts value
end

或者您可以使用Enumerator#next随机次数。

下面的示例基于从数组[true, false]随机选择的truefalse返回具有给定范围内的随机条目的排序数组:

(0..99).select { [true, false].sample }
 => [0, 3, 12, 13, 14, 17, 20, 24, 26, 28, 30, 32, 34, 35, 36, 38, 39, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 53, 54, 55, 56, 58, 59, 60, 61, 62, 65, 67, 69, 70, 71, 79, 81, 84, 86, 91, 93, 94, 95, 98, 99]

为了减少返回更大数组的机会,可以修改true/false数组以包含更多false值:

(0..99).select { ([true] + [false] * 9).sample }
 => [21, 22, 28, 33, 37, 58, 59, 63, 77, 85, 86]

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM