我需要为 3 个不同的对象生成唯一的随机列表,每个对象可以在每个 lis 上出现一次,并且每个代码必须固定长度为 5。
import random
#generate random codes
def generator(code, objects):
for i in range(len(code)):
x = random.choices(objects)
code[i] = x[0]
#Check if code is unique
def isSame(code, list):
if code not in list:
return False
else:
return True
#If code is unique, append it to the codeList and increase counter by 1
codeCount = 0
def listAppend(code, list):
if isSame(code,list) == True:
print('This code is not unique')
else:
list.append(code)
global codeCount
codeCount += 1
if __name__ == '__main__':
codeList = []
desiredCount = 12
while codeCount != desiredCount:
code = [None]*5
objects = ['a','b','c','d','e','f','g']
generator(code, objects)
listAppend(code,codeList)
print(codeList)
这给了我随机的唯一列表,但是我想不出如何让每个对象在每个唯一列表中只出现一次。
例如['a', 'g', 'g', 'a', 'e'] ==> 'g' 和 'a' 重复了两次,我只需要它们出现一次。像,['a','b','c','d','e']
谁能想到一个好方法来做到这一点?谢谢!!
编辑:每个代码的固定长度必须为 5。此外,我使用 random.choices 来使用其概率参数。
答案 0 :(得分:0)
我的做法是:
# Simplify each list to a vector:
data.frame(apply(mydat, 2, simplify2array))
这将从元组/列表/字符串(在我的情况下是字母字符串)生成一个随机元素,并检查该元素是否已经在代码中,如果没有,则将其添加到代码中,长度代码由一个参数决定。
答案 1 :(得分:0)
这将从源中生成所有可能的 3 个唯一元素选择。
from random import randrange as rr
Alphabet="abcdefghijklmnopqrstuvwxyz"
def generate(length):
code=[]
for _ in range(length):
random_number=rr(0,len(Alphabet))
if Alphabet[random_number]not in code:
code.append(Alphabet[random_number])
return code
对于尺寸 5,就是这个列表
import itertools
list(itertools.combinations('abcdefg',3))
[('a', 'b', 'c'),
('a', 'b', 'd'),
('a', 'b', 'e'),
('a', 'b', 'f'),
('a', 'b', 'g'),
('a', 'c', 'd'),
('a', 'c', 'e'),
('a', 'c', 'f'),
...
('d', 'f', 'g'),
('e', 'f', 'g')]
答案 2 :(得分:0)
通过只向函数生成器添加 object.remove() 行,我设法以我想要的方式获得解决方案。
通过删除附加到代码列表中的任何内容,消除了重用。
#generate random codes
def generator(code, objects):
for i in range(len(code)):
x = random.choices(objects)
code[i] = x[0]
#new line
objects.remove(x[0])