生成对Random(0,1)进行调用的Random(a,b)

生成对Random(0,1)进行调用的Random(a,b),第1张

生成对Random(0,1)进行调用的Random(a,b)

如果您的RANDOM(0,1)返回0或1,每个返回的概率为0.5,那么您可以生成位,直到您有足够的二进制数来表示数字(b-a +
1)。这会给您一个随机数,但范围会稍大一些:如果失败,您可以测试并重复。像这样(在Python中)。

def rand_pow2(bit_count):    """Return a random number with the given number of bits."""    result = 0    for i in xrange(bit_count):        result = 2 * result + RANDOM(0, 1)    return resultdef random_range(a, b):    """Return a random integer in the closed interval [a, b]."""    bit_count = math.ceil(math.log2(b - a + 1))    while True:        r = rand_pow2(bit_count)        if a + r <= b: return a + r


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

原文地址: http://outofmemory.cn/zaji/5643194.html

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

发表评论

登录后才能评论

评论列表(0条)

保存