生成范围内的'n'个唯一随机数

Chr*_*and 194 python random unique

我知道如何在Python中生成一个范围内的随机数.

random.randint(numLow, numHigh)
Run Code Online (Sandbox Code Playgroud)

而且我知道我可以把它放在循环中以生成n个这些数字

for x in range (0, n):
    listOfNumbers.append(random.randint(numLow, numHigh))
Run Code Online (Sandbox Code Playgroud)

但是,我需要确保该列表中的每个数字都是唯一的.除了一系列条件语句之外,还有一种生成n个唯一随机数的直接方法吗?

编辑:重要的是列表中的每个数字都与其他数字不同.

所以

[12,5,6,1] =好

[12,5,5,1] =不好,因为数字5出现两次.

Two*_*ist 333

如果您只是需要取样而无需更换:

>>> import random
>>> random.sample(range(1, 100), 3)
[77, 52, 45]
Run Code Online (Sandbox Code Playgroud)

random.sample采用总体和样本大小k并返回k总体的随机成员.

如果你必须控制k大于的情况len(population),你需要准备好抓住ValueError:

>>> try:
...   random.sample(range(1, 2), 3)
... except ValueError:
...   print('Sample size exceeded population size.')
... 
Sample size exceeded population size
Run Code Online (Sandbox Code Playgroud)

  • 如果您使用的是Python2,是的.如果你在我的回答中使用Python 3它已经这样做,因为xrange - > Py3k中的范围. (29认同)
  • 使用`random.sample(xrange(1,100),3)` - 使用**xrange**代替范围 - 可以大大加快代码的速度,特别是如果你有一个很大的范围,因为它只会按需产生需要3个数字(如果没有替换的样本需要它,则需要更多),但不是整个范围.例如:`%timeit random.sample(xrange(10000),3)`=每循环4.92μs,`%timeit random.sample(范围(10000),3)`=每循环126μs (25认同)

the*_*eye 24

首先生成数据范围,然后像这样随机播放

import random
data = range(numLow, numHigh)
random.shuffle(data)
print data
Run Code Online (Sandbox Code Playgroud)

通过这种方式,您将获得特定范围内的所有数字,但是以随机顺序.

但您可以使用random.sample从这样的数字范围中获取所需的元素数量

print random.sample(range(numLow, numHigh), 3)
Run Code Online (Sandbox Code Playgroud)

  • 要在 python 3 中打乱一个范围,你首先需要将它转换为一个列表:`data = list(range(numLow, numHigh))`,否则你会得到一个错误。 (5认同)

mhl*_*ter 12

您可以添加到a,set直到达到n:

setOfNumbers = set()
while len(setOfNumbers) < n:
    setOfNumbers.add(random.randint(numLow, numHigh))
Run Code Online (Sandbox Code Playgroud)

小心范围小于适合的范围n.它将永远循环,无法找到要插入的新数字n


max*_*lis 5

您可以使用标准库中random.sample函数从总体中选择k个元素:

import random
random.sample(range(low, high), n)
Run Code Online (Sandbox Code Playgroud)

如果可能的数字范围很大,则可以使用itertools.islice无限随机生成器:

import itertools
import random

def random_gen(low, high):
    while True:
        yield random.randrange(low, high)

gen = random_gen(1, 100)
items = list(itertools.islice(gen, 10))  # Take first 10 random elements
Run Code Online (Sandbox Code Playgroud)

更新问题后,现在很清楚您需要n个不同的(唯一)数字。

import itertools
import random

def random_gen(low, high):
    while True:
        yield random.randrange(low, high)

gen = random_gen(1, 100)

items = set()

# Try to add elem to set until set length is less than 10
for x in itertools.takewhile(lambda x: len(items) < 10, gen):
    items.add(x)
Run Code Online (Sandbox Code Playgroud)