成人无码视频,亚洲精品久久久久av无码,午夜精品久久久久久毛片,亚洲 中文字幕 日韩 无码

資訊專(zhuān)欄INFORMATION COLUMN

Python每日一練0006

Batkid / 1124人閱讀

摘要:?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.heappushheapq.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

相關(guān)文章

  • Python每日一練0003

    摘要:?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í)候該如...

    happyfish 評(píng)論0 收藏0
  • Python每日一練0002

    摘要:?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...

    yvonne 評(píng)論0 收藏0
  • Python每日一練0024

    摘要:?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...

    wqj97 評(píng)論0 收藏0
  • Python每日一練0023

    摘要:?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()方法...

    wuyangnju 評(píng)論0 收藏0
  • Python每日一練0020

    摘要:?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...

    Berwin 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

Batkid

|高級(jí)講師

TA的文章

閱讀更多
最新活動(dòng)
閱讀需要支付1元查看
<