相关疑难解决方法(0)

选择满足某些属性的随机数组元素

假设我有一个名为的列表,elements每个列表都满足或不满足某些布尔属性p.我想选择一个满足p随机均匀分布的元素.我提前知道有多少物品满足这个属性p.

以下代码会这样做吗?:

pickRandElement(elements, p)
     randElement = null
     count = 0
     foreach element in elements
          if (p(element))
               count = count + 1
               if (randInt(count) == 0)
                    randElement = element

     return randElement
Run Code Online (Sandbox Code Playgroud)

(randInt(n)返回一个随机INT k0 <= k < n.)

arrays algorithm statistics probability

13
推荐指数
2
解决办法
2238
查看次数

标签 统计

algorithm ×1

arrays ×1

probability ×1

statistics ×1