保存最后n個元素

本系列來自python cookbook

問題

有時候,我們只需要保留最新的幾個元素。比如,最新的二十件新鮮事;再比如,五個最近瀏覽的網(wǎng)站。所以我們需要一個獨特的數(shù)據(jù)結(jié)構(gòu),它可以不斷容納新的元素,而當元素量達到容量限制后,先進入容器的元素將依次被丟棄。

class Container:
    def __int__(self, capacity):
        self.capacity = capacity
        self.items = []

    def push(self, item):
        if len(self.items) == self.capacity:
            del self.items[0]
        self.items.append(item)

隊列

沒錯,這就是隊列。事實上,我們可以用collections.deque來解決這個問題。

from collections import deque
q = deque(maxlen=5)
for i in range(20):
    q.append(i)
print q   # deque([15, 16, 17, 18, 19], maxlen=5)
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • java筆記第一天 == 和 equals ==比較的比較的是兩個變量的值是否相等,對于引用型變量表示的是兩個變量...
    jmychou閱讀 1,657評論 0 3
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,656評論 19 139
  • 1.Java集合框架是什么?說出一些集合框架的優(yōu)點? 每種編程語言中都有集合,最初的Java版本包含幾種集合類:V...
    胖先森閱讀 846評論 4 17
  • 【編者按】本文作者為擁有十年金融軟件開發(fā)經(jīng)驗的 Mikhail Vorontsov,文章主要概覽了所有標準 Jav...
    OneAPM_Official閱讀 1,013評論 0 7
  • 版本:Angular 5.0.0-alpha 表單是商業(yè)應(yīng)用的支柱,我們用它來執(zhí)行登錄、求助、下單、預(yù)訂機票、安排...
    soojade閱讀 1,350評論 0 1

友情鏈接更多精彩內(nèi)容