摘要:?jiǎn)栴}在某個(gè)集合中找到最大或最小的個(gè)元素解決方案使用模塊例如此外,這兩個(gè)函數(shù)都可以接受作為參數(shù),例如輸出為討論根據(jù)官方文檔對(duì)的介紹可以了解到提供了堆數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn),并且實(shí)現(xiàn)方式是小頂堆,也就是說(shuō)每次的時(shí)候取出的是最小的元素首先使用將一個(gè)列
問(wèn)題
在某個(gè)集合中找到最大或最小的N個(gè)元素
解決方案使用heapq模塊
heapq.nlargest(n, iterable, key=None)heapq.nsmallest(n, iterable, key=None)
例如:
>>> import heapq >>> l = [9, -2, 0, 8, 1, 3] >>> print(heapq.nlargest(2, l)) [9, 8] >>> print(heapq.nsmallest(2, l)) [-2, 0]
此外,這兩個(gè)函數(shù)都可以接受key作為參數(shù),例如:
import heapq fruits = [ {"name": "orange", "price": 5}, {"name": "apple", "price": 2}, {"name": "pear", "price": 1.5}, {"name": "lemon", "price": 3}, ] print(heapq.nlargest(2, fruits, key=lambda x: x["price"]))
輸出為:
[{"name": "orange", "price": 5}, {"name": "lemon", "price": 3}]討論
根據(jù)Python3官方文檔對(duì)heapq的介紹可以了解到
heapq提供了堆數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn),并且實(shí)現(xiàn)方式是小頂堆,也就是說(shuō)每次pop的時(shí)候取出的是最小的元素
首先使用heapq.heapify將一個(gè)列表初始化為堆
>>> import heapq >>> l = [-1, 2, 5, 0, 8] >>> heapq.heapify(l) >>> print(l) [-1, 0, 5, 2, 8]
然后就可以調(diào)用heapq.heappush和heapq.heappop對(duì)堆進(jìn)行增加和刪除操作了
>>> heapq.heappush(l, 8) >>> print(l) [-1, 0, 5, 2, 8, 8] >>> print(heapq.heappop(l)) -1
此外,heapq還提供了其他堆的一些操作
heapq.heappushpop(heap, item)先將item存入堆中,然后彈出最小的元素,相當(dāng)于先調(diào)用了heapq.heappush(item)再調(diào)用heapq.heappop(),但這樣調(diào)用會(huì)比分開(kāi)調(diào)用兩個(gè)函數(shù)效率更高
heapq.heapreplace(heap, item)先彈出最小的元素,再存入item
heapq.merge(*iterables, key=None, reverse=False)將多個(gè)有序的集合合并成一個(gè)有序的集合,并且返回的是迭代器對(duì)象
來(lái)源Python Cookbook
關(guān)注歡迎關(guān)注我的微信公眾號(hào):python每日一練
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://m.hztianpu.com/yun/44679.html
摘要:?jiǎn)栴}在每日一練中介紹了如何一個(gè)可迭代對(duì)象,使用運(yùn)算符即可但往往我們遇到的問(wèn)題是可迭代對(duì)象中的數(shù)量是不確定的這個(gè)時(shí)候該如何拿到我們想要的元素,比如我們只需要可迭代對(duì)象的第一個(gè)或者最后一個(gè)元素而已解決方案使用中的運(yùn)算符例如我們需要拿到一個(gè)元組的 問(wèn)題 在每日一練0001中介紹了如何unpack一個(gè)可迭代對(duì)象,使用,運(yùn)算符即可 但往往我們遇到的問(wèn)題是可迭代對(duì)象中的數(shù)量是不確定的 這個(gè)時(shí)候該如...
摘要:?jiǎn)栴}如何序列化輸出元素包含字符串元組的字符串元組好繞舉個(gè)例子將輸出為解決方案容易想到使用函數(shù),但函數(shù)要求元素必須都是字符串類(lèi)型,否則會(huì)拋出錯(cuò)誤一個(gè)比較簡(jiǎn)單的方法是將給進(jìn)中,然后再將給進(jìn)函數(shù),最后指定函數(shù)的參數(shù)來(lái)輸出如果想要將結(jié)果存儲(chǔ)起來(lái),那 問(wèn)題 如何序列化輸出元素包含字符串元組的字符串元組(好繞) 舉個(gè)例子 >>> zoo1 = (monkey, elephant) >>> zoo2...
摘要:?jiǎn)栴}如何執(zhí)行外部命令,如解決方案使用庫(kù)在之前,使用函數(shù)在及之后,使用函數(shù)討論命令的執(zhí)行默認(rèn)不需要環(huán)境,所以當(dāng)你使用作為參數(shù)時(shí),需要將置位,否則會(huì)報(bào)錯(cuò)誤通常來(lái)說(shuō)對(duì)于執(zhí)行系統(tǒng)命令,我們會(huì)想到,但在官方文檔中已經(jīng)建議了使 問(wèn)題 如何執(zhí)行外部命令,如ls -l 解決方案 使用subprocess庫(kù) 在Python 3.5之前,使用subprocess.call()函數(shù) >>> import s...
摘要:?jiǎn)栴}如何判斷一個(gè)文件是否存在解決方案這個(gè)問(wèn)題可以分成幾類(lèi)問(wèn)題如果這里的文件指的是文件或目錄,我們可以用方法如果這里的文件指的是普通的文件,我們可以用方法如果這里的文件指的是目錄,我們可以用方法并且在之后,可以使用面向?qū)ο蟮姆椒ㄊ褂脦?kù)來(lái)判斷, 問(wèn)題 如何判斷一個(gè)文件是否存在 解決方案 這個(gè)問(wèn)題可以分成幾類(lèi)問(wèn)題 如果這里的文件指的是文件或目錄,我們可以用os.path.exists()方法...
摘要:?jiǎn)栴}你需要執(zhí)行簡(jiǎn)單的日期操作,計(jì)算兩個(gè)日期間隔多少天某個(gè)日期后的多少天是幾月幾日轉(zhuǎn)換時(shí)間字符串的格式等解決方案使用庫(kù)中的和類(lèi)其中類(lèi)代表一個(gè)日期時(shí)間,例如年月日點(diǎn)分秒類(lèi)代表一個(gè)日期間隔對(duì)于實(shí)例,可以直接進(jìn)行數(shù)學(xué)運(yùn)算得到一個(gè)實(shí)例,也就是兩個(gè)日 問(wèn)題 你需要執(zhí)行簡(jiǎn)單的日期操作,計(jì)算兩個(gè)日期間隔多少天、某個(gè)日期后的多少天是幾月幾日、轉(zhuǎn)換時(shí)間字符串的格式等 解決方案 使用datetime庫(kù)中的d...
閱讀 594·2019-08-30 15:55
閱讀 1011·2019-08-29 15:35
閱讀 1266·2019-08-29 13:48
閱讀 1998·2019-08-26 13:29
閱讀 3011·2019-08-23 18:26
閱讀 1309·2019-08-23 18:20
閱讀 2889·2019-08-23 16:43
閱讀 2760·2019-08-23 15:58