一、random库函数shuffle()
Python中的random库提供了shuffle()函数,可以直接对列表进行随机打乱,这种方法是最简单易用的。
<python>
import random
list1 = [1, 2, 3, 4, 5]
random.shuffle(list1)
print(list1)
>
执行以上代码,会输出随机打乱过的列表[4, 5, 3, 1, 2]。
需要注意的是,shuffle()函数直接改变了原来的列表,使用之前需要备份原来的列表。
二、sorted函数结合random库函数random()实现
Python中sorted()函数可以将列表排序,配合random库函数random()进行随机排序。
<python>
import random
list1 = [1, 2, 3, 4, 5]
list2 = sorted(list1, key=lambda x: random.random())
print(list2)
>
执行以上代码,会输出随机打乱过的列表,例如[1, 5, 4, 2, 3]。
在这个方法中,key参数指定了sorted()函数按照random()函数生成的随机数进行排序,进而实现了随机排序的效果。需要注意的是,该方法每次执行结果都会不同,具有随机性。
三、numpy库函数random.permutation()
numpy是Python的第三方库,提供了很多常用的数学、科学计算函数。numpy库中的permutation()函数可以对给定长度的序列进行随机操作。
<python>
import numpy as np
list1 = [1, 2, 3, 4, 5]
list2 = np.random.permutation(list1)
print(list2)
>
执行以上代码,会输出随机打乱过的列表,例如[5, 1, 3, 2, 4]。
需要注意的是,numpy库中的random.permutation()函数返回的是一个新列表,原始列表不变。
四、Fisher–Yates算法
Fisher–Yates算法,也称为Knuth洗牌算法,是一种常用的随机打乱列表的算法。该算法可以保证整个序列都是完全随机的。
<python>
import random
list1 = [1, 2, 3, 4, 5]
for i in range(len(list1) - 1, 0, -1):
j = random.randint(0, i)
list1[i], list1[j] = list1[j], list1[i]
print(list1)
>
执行以上代码,会输出随机打乱过的列表,例如[2, 4, 3, 5, 1]。
该算法的原理是从最后一个数开始,随机生成一个位置j(范围在[0,i]),将第i个数与第j个数交换;然后将倒数第二个数进行相同的操作,以此类推,直到第一个位置。这个算法可以保证整个序列都是完全随机的。
五、小结
本篇文章介绍了Python实现随机打乱列表的四种方法:使用random库函数shuffle()、使用sorted函数结合random库函数random()、使用numpy库函数random.permutation()、使用Fisher–Yates算法。可以根据实际情况选择相应的方法,实现随机打乱列表。