解决方法之一是使用集合(Set)来存储已经选择过的元素,这样可以避免重复出现。
以下是一个示例代码,用于从一个列表中随机选择元素,并确保不会出现重复的元素:
import random
def random_choice_without_duplicates(lst):
selected = set()
result = []
while len(selected) < len(lst):
choice = random.choice(lst)
if choice not in selected:
selected.add(choice)
result.append(choice)
return result
使用示例:
my_list = [1, 2, 3, 4, 5]
result = random_choice_without_duplicates(my_list)
print(result)
上述代码首先创建了一个空集合 selected
和一个空列表 result
。然后,它进入一个循环,直到 selected
中的元素数量等于 lst
的长度。
在循环中,它使用 random.choice()
函数从 lst
中随机选择一个元素,并检查这个元素是否已经存在于 selected
中。如果不存在,则将其添加到 selected
中,并将其添加到 result
列表中。
最后,返回 result
列表,其中包含了随机选择的元素,且不会出现重复的元素。
下一篇:避免从一列重复