日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程语言 > python >内容正文

python

python 随机排序_Python 如何随机打乱列表(List)排序

發(fā)布時(shí)間:2023/12/3 python 48 豆豆
生活随笔 收集整理的這篇文章主要介紹了 python 随机排序_Python 如何随机打乱列表(List)排序 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

場景:

現(xiàn)在有一個(gè)list:[1,2,3,4,5,6],我需要把這個(gè)list在輸出的時(shí)候,是以一種隨機(jī)打亂的形式輸出。

專業(yè)點(diǎn)的術(shù)語:將一個(gè)容器中的數(shù)據(jù)每次隨機(jī)逐個(gè)遍歷一遍。

注意:不是生成一個(gè)隨機(jī)的list集。

環(huán)境:

Python 3.6

解決方案:

方案一:

有人可能會(huì)通過Random內(nèi)置函數(shù),來間接實(shí)現(xiàn)想要的結(jié)果。但是這種方式,太原始,也不夠優(yōu)雅,而且有種重復(fù)造輪子的嫌疑。這里我就不貼我自己通過random實(shí)現(xiàn)的效果了。

方案二:

Random中有一個(gè)random.shuffle()方法提供了完美的解決方案。代碼如下:

x = [1,2,3,4,5,6]

random.shuffle(x)

print(x)

輸出結(jié)果:

第一次輸出內(nèi)容:[6, 5, 1, 3, 2, 4]

第二次輸出內(nèi)容:[6, 1, 3, 5, 2, 4]

第三次輸出內(nèi)容:[5, 3, 1, 2, 4, 6]

從結(jié)果我們可以看出,輸出是完全隨機(jī)的,代碼量就兩行,不需要random,不需要for循環(huán)。

源碼解讀:

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.

可選參數(shù)random是一個(gè)從0到參數(shù)的函數(shù),返回[0.0,1.0)中的隨機(jī)浮點(diǎn);

如果random是缺省值None,則將使用標(biāo)準(zhǔn)的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,請注意這個(gè)細(xì)節(jié)。

本文首發(fā)于BigYoung小站

創(chuàng)作挑戰(zhàn)賽新人創(chuàng)作獎(jiǎng)勵(lì)來咯,堅(jiān)持創(chuàng)作打卡瓜分現(xiàn)金大獎(jiǎng)

總結(jié)

以上是生活随笔為你收集整理的python 随机排序_Python 如何随机打乱列表(List)排序的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。