具有概率的随机数

具有概率的随机数,第1张

具有概率的随机数

您的方法已经相当不错,并且可以在任何范围内正常工作。

只是想一想:另一种可能性是通过乘以常数乘数来去除分数,然后构建具有该乘数 大小数组。乘以10得到

P(1) = 2P(2) = 3P(3) = 5

然后创建一个具有相反值的数组-‘1’进入元素1和2,‘2’进入元素3至6,依此类推:

P =(1,1,2,2,2,3,3,3,3,3);

然后您可以从此数组中选择一个随机元素。


(添加。)使用kiruwka注释中的示例中的概率:

int[] numsToGenerate= new int[]    { 1,   2,    3,   4,    5   };double[] discreteProbabilities = new double[] { 0.1, 0.25, 0.3, 0.25, 0.1 };

导致全整数的最小乘数是20

2, 5, 6, 5, 2

因此长度为

numsToGenerate
20,具有以下值:

1 12 2 2 2 23 3 3 3 3 34 4 4 4 45 5

分布 完全相同 :例如,“ 1”的机率现在是20中的2,仍然是0.1。

这是基于您的原始概率加总为1的结果。如果不然,则将总数乘以相同的因子(这也将成为您的数组长度)。



欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/zaji/5176044.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2022-11-18
下一篇2022-11-18

发表评论

登录后才能评论

评论列表(0条)

    保存