基于Python中random.sample()的替代方案
python中random.sample()方法可以隨機(jī)地從指定列表中提取出N個(gè)不同的元素,但在實(shí)踐中發(fā)現(xiàn),當(dāng)N的值比較大的時(shí)候,該方法執(zhí)行速度很慢,如:
numpy random模塊中的choice方法可以有效提升隨機(jī)提取的效率:
需要注意的是,需要置replace為False,即抽取的元素不能重復(fù),默認(rèn)為True。
補(bǔ)充知識(shí):Python: random模塊的隨即取樣函數(shù):choice(),choices(),sample()
choice(seq): 從seq序列中(可以是列表,元組,字符串)隨機(jī)取一個(gè)元素返回
choices(population, weights=None, *, cum_weights=None, k=1):
從population中進(jìn)行K次隨機(jī)選取,每次選取一個(gè)元素(注意會(huì)出現(xiàn)同一個(gè)元素多次被選中的情況),weights是相對(duì)權(quán)重值,population中有幾個(gè)元素就要有相對(duì)應(yīng)的weights值,cum_weights是累加權(quán)重值,例如,相對(duì)權(quán)重〔10, 5, 30,5〕相當(dāng)于累積權(quán)重〔10, 15, 45,50〕。
在內(nèi)部,在進(jìn)行選擇之前,相對(duì)權(quán)重被轉(zhuǎn)換為累積權(quán)重,因此提供累積權(quán)重節(jié)省了工作。返回一個(gè)列表。
sample(population, k)從population中取樣,一次取k個(gè),返回一個(gè)k長(zhǎng)的列表。
可以像這樣使用sample(range(10000000), k=60)
以上這篇基于Python中random.sample()的替代方案就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. CSS清除浮動(dòng)方法匯總2. XML入門的常見(jiàn)問(wèn)題(三)3. HTML5實(shí)戰(zhàn)與剖析之觸摸事件(touchstart、touchmove和touchend)4. React優(yōu)雅的封裝SvgIcon組件示例5. CSS百分比padding制作圖片自適應(yīng)布局6. js開(kāi)發(fā)中的頁(yè)面、屏幕、瀏覽器的位置原理(高度寬度)說(shuō)明講解(附圖)7. XML 非法字符(轉(zhuǎn)義字符)8. 不要在HTML中濫用div9. 深入了解React中的合成事件10. TypeScript實(shí)現(xiàn)十大排序算法之歸并排序示例詳解
