国产av日韩一区二区三区精品,成人性爱视频在线观看,国产,欧美,日韩,一区,www.成色av久久成人,2222eeee成人天堂

目錄
Creating and Initializing a Deque
Adding and Removing Elements Efficiently
Rotating and Managing Elements
When to Use Deque Instead of List
首頁(yè) 后端開(kāi)發(fā) Python教程 如何使用Python中的集合模塊中的Deque數(shù)據(jù)結(jié)構(gòu)?

如何使用Python中的集合模塊中的Deque數(shù)據(jù)結(jié)構(gòu)?

Jun 22, 2025 am 12:56 AM

Python的deque適用于需要高效處理兩端操作的場(chǎng)景。1. 創(chuàng)建時(shí)可傳入列表或字符串,也可初始化為空再添加元素;2. 使用append()和appendleft()分別在右端和左端添加元素;3. 使用pop()和popleft()分別從右端和左端移除元素;4. rotate(n)方法將元素向右(正數(shù))或向左(負(fù)數(shù))循環(huán)移動(dòng);5. 設(shè)置maxlen參數(shù)后,超出容量時(shí)會(huì)自動(dòng)丟棄對(duì)端舊元素;6. 適合用于隊(duì)列、滑動(dòng)窗口、歷史記錄等場(chǎng)景。相比列表,deque在首部操作具有O(1)時(shí)間復(fù)雜度,性能更優(yōu)。

How do I use the deque data structure from the collections module in Python?

The deque (double-ended queue) from Python’s collections module is a versatile and efficient data structure, especially when you need fast appends and pops from both ends. If you're used to working with lists, switching to deque can give you performance boosts in certain situations.

Let’s break down how to use it effectively.


Creating and Initializing a Deque

To start using deque, you first need to import it from the collections module. Then you can create one by passing in an iterable like a list or string.

from collections import deque

d = deque([1, 2, 3])

You can also initialize it empty and add elements later. It's pretty flexible — strings, tuples, and even other deques work as input.

If you're starting from scratch:

  • Use append() to add to the right end
  • Use appendleft() to add to the left end
d = deque()
d.append(1)        # deque([1])
d.appendleft(0)    # deque([0, 1])

Adding and Removing Elements Efficiently

One of the main advantages of deque over regular lists is its speed for operations at both ends. With a normal list, inserting or removing from the front (pop(0) or insert(0, x)) takes O(n) time, which gets slow for large data sets. deque does these operations in O(1) time.

Here are some common operations:

  • Add to the right: append(x)
  • Add to the left: appendleft(x)
  • Remove from the right: pop()
  • Remove from the left: popleft()
d = deque([1, 2, 3])
d.append(4)       # deque([1, 2, 3, 4])
d.popleft()       # returns 1 → deque([2, 3, 4])

This makes deque perfect for things like queues or sliding window problems.


Rotating and Managing Elements

Another handy feature is the rotate() method. It shifts elements in place to the right (or left if given a negative number).

For example:

d = deque([1, 2, 3, 4, 5])
d.rotate(1)   # deque([5, 1, 2, 3, 4])

That moves each element one position to the right, wrapping around the end. A negative rotation goes the other way:

d.rotate(-1)  # back to deque([1, 2, 3, 4, 5])

Also, if you ever need to limit the size of your deque, you can set the maxlen parameter when creating it. Once full, adding new items will automatically drop the oldest ones from the opposite end.

d = deque(maxlen=3)
d.append(1)
d.append(2)
d.append(3)
d.append(4)   # now contains [2, 3, 4]

This is super useful for tracking recent values or implementing fixed-size buffers.


When to Use Deque Instead of List

In most cases, you’ll still want to use a regular list. But if you find yourself frequently doing:

  • Insertions/removals at the beginning
  • Implementing queues or stacks
  • Maintaining a history or buffer of recent items

Then deque is the better choice.

Even though they look similar and support many of the same methods, their performance characteristics differ. So if you're building something that needs high efficiency on both ends, switch to deque.


基本上就這些。掌握幾個(gè)常用方法之后,你會(huì)發(fā)現(xiàn)它在很多場(chǎng)景下比列表更合適,而且用起來(lái)也不復(fù)雜。

以上是如何使用Python中的集合模塊中的Deque數(shù)據(jù)結(jié)構(gòu)?的詳細(xì)內(nèi)容。更多信息請(qǐng)關(guān)注PHP中文網(wǎng)其他相關(guān)文章!

本站聲明
本文內(nèi)容由網(wǎng)友自發(fā)貢獻(xiàn),版權(quán)歸原作者所有,本站不承擔(dān)相應(yīng)法律責(zé)任。如您發(fā)現(xiàn)有涉嫌抄襲侵權(quán)的內(nèi)容,請(qǐng)聯(lián)系admin@php.cn

熱AI工具

Undress AI Tool

Undress AI Tool

免費(fèi)脫衣服圖片

Undresser.AI Undress

Undresser.AI Undress

人工智能驅(qū)動(dòng)的應(yīng)用程序,用于創(chuàng)建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用于從照片中去除衣服的在線人工智能工具。

Clothoff.io

Clothoff.io

AI脫衣機(jī)

Video Face Swap

Video Face Swap

使用我們完全免費(fèi)的人工智能換臉工具輕松在任何視頻中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費(fèi)的代碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

功能強(qiáng)大的PHP集成開(kāi)發(fā)環(huán)境

Dreamweaver CS6

Dreamweaver CS6

視覺(jué)化網(wǎng)頁(yè)開(kāi)發(fā)工具

SublimeText3 Mac版

SublimeText3 Mac版

神級(jí)代碼編輯軟件(SublimeText3)

熱門(mén)話題

Laravel 教程
1600
29
PHP教程
1502
276
如何處理Python中的API身份驗(yàn)證 如何處理Python中的API身份驗(yàn)證 Jul 13, 2025 am 02:22 AM

處理API認(rèn)證的關(guān)鍵在于理解并正確使用認(rèn)證方式。1.APIKey是最簡(jiǎn)單的認(rèn)證方式,通常放在請(qǐng)求頭或URL參數(shù)中;2.BasicAuth使用用戶(hù)名和密碼進(jìn)行Base64編碼傳輸,適合內(nèi)部系統(tǒng);3.OAuth2需先通過(guò)client_id和client_secret獲取Token,再在請(qǐng)求頭中帶上BearerToken;4.為應(yīng)對(duì)Token過(guò)期,可封裝Token管理類(lèi)自動(dòng)刷新Token;總之,根據(jù)文檔選擇合適方式,并安全存儲(chǔ)密鑰信息是關(guān)鍵。

解釋Python斷言。 解釋Python斷言。 Jul 07, 2025 am 12:14 AM

Assert是Python用于調(diào)試的斷言工具,當(dāng)條件不滿(mǎn)足時(shí)拋出AssertionError。其語(yǔ)法為assert條件加可選錯(cuò)誤信息,適用于內(nèi)部邏輯驗(yàn)證如參數(shù)檢查、狀態(tài)確認(rèn)等,但不能用于安全或用戶(hù)輸入檢查,且應(yīng)配合清晰提示信息使用,僅限開(kāi)發(fā)階段輔助調(diào)試而非替代異常處理。

什么是Python型提示? 什么是Python型提示? Jul 07, 2025 am 02:55 AM

typeHintsInpyThonsolverbromblemboyofambiguityandPotentialBugSindyNamalytyCodeByallowingDevelopsosteSpecefectifyExpectedTypes.theyenhancereadability,enablellybugdetection,andimprovetool.typehintsupport.typehintsareadsareadsareadsareadsareadsareadsareadsareadsareaddedusidocolon(

如何一次迭代兩個(gè)列表 如何一次迭代兩個(gè)列表 Jul 09, 2025 am 01:13 AM

在Python中同時(shí)遍歷兩個(gè)列表的常用方法是使用zip()函數(shù),它會(huì)按順序配對(duì)多個(gè)列表并以最短為準(zhǔn);若列表長(zhǎng)度不一致,可使用itertools.zip_longest()以最長(zhǎng)為準(zhǔn)并填充缺失值;結(jié)合enumerate()可同時(shí)獲取索引。1.zip()簡(jiǎn)潔實(shí)用,適合成對(duì)數(shù)據(jù)迭代;2.zip_longest()處理不一致長(zhǎng)度時(shí)可填充默認(rèn)值;3.enumerate(zip())可在遍歷時(shí)獲取索引,滿(mǎn)足多種復(fù)雜場(chǎng)景需求。

什么是Python迭代器? 什么是Python迭代器? Jul 08, 2025 am 02:56 AM

Inpython,IteratorSareObjectSthallowloopingThroughCollectionsByImplementing_iter __()和__next __()。1)iteratorsWiaTheIteratorProtocol,使用__ITER __()toreTurnterateratoratoranteratoratoranteratoratorAnterAnteratoratorant antheittheext__()

Python Fastapi教程 Python Fastapi教程 Jul 12, 2025 am 02:42 AM

要使用Python創(chuàng)建現(xiàn)代高效的API,推薦使用FastAPI;其基于標(biāo)準(zhǔn)Python類(lèi)型提示,可自動(dòng)生成文檔,性能優(yōu)越。安裝FastAPI和ASGI服務(wù)器uvicorn后,即可編寫(xiě)接口代碼。通過(guò)定義路由、編寫(xiě)處理函數(shù)并返回?cái)?shù)據(jù),可以快速構(gòu)建API。FastAPI支持多種HTTP方法,并提供自動(dòng)生成的SwaggerUI和ReDoc文檔系統(tǒng)。URL參數(shù)可通過(guò)路徑定義捕獲,查詢(xún)參數(shù)則通過(guò)函數(shù)參數(shù)設(shè)置默認(rèn)值實(shí)現(xiàn)。合理使用Pydantic模型有助于提升開(kāi)發(fā)效率和準(zhǔn)確性。

如何用Python測(cè)試API 如何用Python測(cè)試API Jul 12, 2025 am 02:47 AM

要測(cè)試API需使用Python的Requests庫(kù),步驟為安裝庫(kù)、發(fā)送請(qǐng)求、驗(yàn)證響應(yīng)、設(shè)置超時(shí)與重試。首先通過(guò)pipinstallrequests安裝庫(kù);接著用requests.get()或requests.post()等方法發(fā)送GET或POST請(qǐng)求;然后檢查response.status_code和response.json()確保返回結(jié)果符合預(yù)期;最后可添加timeout參數(shù)設(shè)置超時(shí)時(shí)間,并結(jié)合retrying庫(kù)實(shí)現(xiàn)自動(dòng)重試以增強(qiáng)穩(wěn)定性。

Python函數(shù)可變范圍 Python函數(shù)可變范圍 Jul 12, 2025 am 02:49 AM

在Python中,函數(shù)內(nèi)部定義的變量是局部變量,僅在函數(shù)內(nèi)有效;外部定義的是全局變量,可在任何地方讀取。1.局部變量隨函數(shù)執(zhí)行結(jié)束被銷(xiāo)毀;2.函數(shù)可訪問(wèn)全局變量但不能直接修改,需用global關(guān)鍵字;3.嵌套函數(shù)中若要修改外層函數(shù)變量,需使用nonlocal關(guān)鍵字;4.同名變量在不同作用域互不影響;5.修改全局變量時(shí)必須聲明global,否則會(huì)引發(fā)UnboundLocalError錯(cuò)誤。理解這些規(guī)則有助于避免bug并寫(xiě)出更可靠的函數(shù)。

See all articles