python随机排序_Python如何随机打乱列表(List)排序
场景:
现在有⼀个list:[1,2,3,4,5,6],我需要把这个list在输出的时候,是以⼀种随机打乱的形式输出。
random python专业点的术语:将⼀个容器中的数据每次随机逐个遍历⼀遍。
注意:不是⽣成⼀个随机的list集。
环境:
Python 3.6
解决⽅案:
⽅案⼀:
有⼈可能会通过Random内置函数,来间接实现想要的结果。但是这种⽅式,太原始,也不够优雅,⽽且有种重复造轮⼦的嫌疑。这⾥我就不贴我⾃⼰通过random实现的效果了。
⽅案⼆:
Random中有⼀个random.shuffle()⽅法提供了完美的解决⽅案。代码如下:
x = [1,2,3,4,5,6]
random.shuffle(x)
print(x)
输出结果:
第⼀次输出内容:[6, 5, 1, 3, 2, 4]
第⼆次输出内容:[6, 1, 3, 5, 2, 4]
第三次输出内容:[5, 3, 1, 2, 4, 6]
从结果我们可以看出,输出是完全随机的,代码量就两⾏,不需要random,不需要for循环。
源码解读:
def shuffle(self, x, random=None):
"""Shuffle list x in place, and return None.
原位打乱列表,不⽣成新的列表。
Optional argument random is a 0-argument
function returning a random float in [0.0, 1.0);
if it is the default None,
the standard random.random will be used.
可选参数random是⼀个从0到参数的函数,返回[0.0,1.0)中的随机浮点;
如果random是缺省值None,则将使⽤标准的random.random()。
"""
if random is None:
randbelow = self._randbelow
for i in reversed(range(1, len(x))):
# pick an element in x[:i+1] with which to exchange x[i]
j = randbelow(i + 1)
x[i], x[j] = x[j], x[i]
else:
_int = int
for i in reversed(range(1, len(x))):
# pick an element in x[:i+1] with which to exchange x[i]
j = _int(random() * (i + 1))
x[i], x[j] = x[j], x[i]
注意 :
从代码的注释,我们看到random.shuffle()是对原list做修改,如果需要保留原list,请注意这个细节。本⽂⾸发于BigYoung⼩站
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论