欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Python?queue雙端隊列模塊及用法小結(jié)

 更新時間:2024年02月02日 12:02:12   作者:hakesashou  
雙端隊列是一種具有隊列和棧性質(zhì)的線性數(shù)據(jù)結(jié)構(gòu),本文主要介紹了Python?queue雙端隊列模塊及用法小結(jié),文中通過示例代碼介紹的非常詳細(xì),需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

在“數(shù)據(jù)結(jié)構(gòu)”課程中最常講授的數(shù)據(jù)結(jié)構(gòu)有棧、隊列、雙端隊列。

棧是一種特殊的線性表,它只允許在一端進(jìn)行插入、刪除操作,這一端被稱為棧頂(top),另一端則被稱為棧底(bottom)。

從棧頂插入一個元素被稱為進(jìn)棧,將一個元素插入棧頂被稱為“壓入棧”,對應(yīng)的英文說法為 push;相應(yīng)地,從棧頂刪除一個元素被稱為出棧,將一個元素從棧頂刪除被稱為“彈出棧”,對應(yīng)的英文說法為 pop。

對于棧而言,最先入棧的元素位于棧底,只有等到上面所有元素都出棧之后,棧底的元素才能出棧。因此棧是一種后進(jìn)先出(LIFO)的線性表。如圖 1 所示為棧的操作示意圖。

2-1Z225151411626 (1).gif

隊列也是一種特殊的線性表,它只允許在表的前端(front)進(jìn)行刪除操作,在表的后端(rear)進(jìn)行插入操作。進(jìn)行插入操作的端被稱為隊尾,進(jìn)行刪除操作的端被稱為隊頭。

對于一個隊列來說,每個元素總是從隊列的 rear 端進(jìn)入隊列的,然后等待該元素之前的所有元素都出隊之后,當(dāng)前元素才能出隊。因此,隊列是一種先進(jìn)先出(FIFO)的線性表。隊列示意圖如圖 2 所示。

2-1Z22515142N00.gif

雙端隊列(即此處介紹的 deque)代表一種特殊的隊列,它可以在兩端同時進(jìn)行插入、刪除操作,如圖 3 所示。

2-1Z225151440Z7.gif

對于一個雙端隊列來說,它可以從兩端分別進(jìn)行插入、刪除操作,如果程序?qū)⑺械牟迦?、刪除操作都固定在一端進(jìn)行,那么這個雙端隊列就變成了棧;如果固定在一端只添加元素,在另一端只刪除元素,那么它就變成了隊列。因此,deque 既可被當(dāng)成隊列使用,也可被當(dāng)成棧使用。

deque 位于 collections 包下,在交互式解釋器中先導(dǎo)入 collections 包,然后輸入 [e for e in dir(collections.deque) if not e.startswith('_')] 命令來查看 deque 的全部方法,可以看到如下輸出結(jié)果:

>>> from collections import deque
>>> [e for e in dir(deque) if not e.startswith('_')]
['append', 'appendleft', 'clear', 'copy', 'count', 'extend', 'extendleft', 'index', 'insert', 'maxlen', 'pop', 'popleft', 'remove', 'reverse', 'rotate']

從上面的方法可以看出,deque 的方法基本都有兩個版本,這就體現(xiàn)了它作為雙端隊列的特征。deque 的左邊(left)就相當(dāng)于它的隊列頭(front),右邊(right)就相當(dāng)于它的隊列尾(rear):

append 和 appendleft:在 deque 的右邊或左邊添加元素,也就是默認(rèn)在隊列尾添加元素。

pop 和 popleft:在 deque 的右邊或左邊彈出元素,也就是默認(rèn)在隊列尾彈出元素。

extend 和 extendleft:在 deque 的右邊或左邊添加多個元素,也就是默認(rèn)在隊列尾添加多個元素。

deque 中的 clear() 方法用于清空隊列:insert() 方法則是線性表的方法,用于在指定位置插入元素。

假如程序要把 deque 當(dāng)成棧使用,則意味著只在一端添加、刪除元素,因此調(diào)用 append 和 pop 方法即可。例如如下程序:

從上面的方法可以看出,deque 的方法基本都有兩個版本,這就體現(xiàn)了它作為雙端隊列的特征。deque 的左邊(left)就相當(dāng)于它的隊列頭(front),右邊(right)就相當(dāng)于它的隊列尾(rear):

append 和 appendleft:在 deque 的右邊或左邊添加元素,也就是默認(rèn)在隊列尾添加元素。

pop 和 popleft:在 deque 的右邊或左邊彈出元素,也就是默認(rèn)在隊列尾彈出元素。

extend 和 extendleft:在 deque 的右邊或左邊添加多個元素,也就是默認(rèn)在隊列尾添加多個元素。

deque 中的 clear() 方法用于清空隊列:insert() 方法則是線性表的方法,用于在指定位置插入元素。

假如程序要把 deque 當(dāng)成棧使用,則意味著只在一端添加、刪除元素,因此調(diào)用 append 和 pop 方法即可。例如如下程序:

from collections import deque
stack = deque(('Kotlin', 'Python'))
# 元素入棧
stack.append('Erlang')
stack.append('Swift')
print('stack中的元素:' , stack)
# 元素出棧,后添加的元素先出棧
print(stack.pop())
print(stack.pop())
print(stack)

運(yùn)行上面程序,可以看到如下運(yùn)行結(jié)果:

stack中的元素: deque(['Kotlin', 'Python', 'Erlang', 'Swift'])
Swift
Erlang
deque(['Kotlin', 'Python'])

從上面的運(yùn)行結(jié)果可以看出,程序最后入棧的元素“Swift”最先出棧,這體現(xiàn)了棧的 LIFO 的特征。
假如程序要把 deque 當(dāng)成隊列使用,則意味著一端只用來添加元素,另一端只用來刪除元素,因此調(diào)用 append、popleft 方法即可。例如如下程序:

from collections import deque
q = deque(('Kotlin', 'Python'))
# 元素加入隊列
q.append('Erlang')
q.append('Swift')
print('q中的元素:' , q)
# 元素出隊列,先添加的元素先出隊列
print(q.popleft())
print(q.popleft())
print(q)

運(yùn)行上面程序,可以看到如下運(yùn)行結(jié)果:

q中的元素: deque(['Kotlin', 'Python', 'Erlang', 'Swift'])
Kotlin
Python
deque(['Erlang', 'Swift'])

從上面的運(yùn)行結(jié)果可以看出,程序先添加的元素“Katlin”最先出隊列,這體現(xiàn)了隊列的 FIFO 的特征。

此外,deque 還有一個 rotate() 方法,該方法的作用是將隊列的隊尾元素移動到隊頭,使之首尾相連。例如如下程序:

from collections import deque
q = deque(range(5))
print('q中的元素:' , q)
# 執(zhí)行旋轉(zhuǎn),使之首尾相連
q.rotate()
print('q中的元素:' , q)
# 再次執(zhí)行旋轉(zhuǎn),使之首尾相連
q.rotate()
print('q中的元素:' , q)

運(yùn)行上面程序,可以看到如下輸出結(jié)果:

q中的元素: deque([0, 1, 2, 3, 4])
q中的元素: deque([4, 0, 1, 2, 3])
q中的元素: deque([3, 4, 0, 1, 2])

從上面的輸出結(jié)果來看,每次執(zhí)行 rotate() 方法,deque 的隊尾元素都會被移到隊頭,這樣就形成了首尾相連的效果。

到此這篇關(guān)于Python queue雙端隊列模塊及用法小結(jié)的文章就介紹到這了,更多相關(guān)Python queue雙端隊列內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • python爬蟲之Appium爬取手機(jī)App數(shù)據(jù)及模擬用戶手勢

    python爬蟲之Appium爬取手機(jī)App數(shù)據(jù)及模擬用戶手勢

    這篇文章主要介紹了python爬蟲怎樣通過Appium爬取手機(jī)App數(shù)據(jù)及模擬用戶手勢,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-08-08
  • python標(biāo)準(zhǔn)日志模塊logging的使用方法

    python標(biāo)準(zhǔn)日志模塊logging的使用方法

    python的標(biāo)準(zhǔn)庫里的日志系統(tǒng)從Python2.3開始支持。只要import logging這個模塊即可使用。
    2013-11-11
  • python爬蟲Scrapy框架:媒體管道原理學(xué)習(xí)分析

    python爬蟲Scrapy框架:媒體管道原理學(xué)習(xí)分析

    這篇文章主要介紹了python爬蟲Scrapy框架:媒體管道原理學(xué)習(xí)分析,有需要的朋友可以借鑒參考,希望可以對廣大一同學(xué)習(xí)的讀者朋友有所幫助
    2021-09-09
  • python順序的讀取文件夾下名稱有序的文件方法

    python順序的讀取文件夾下名稱有序的文件方法

    今天小編就為大家分享一篇python順序的讀取文件夾下名稱有序的文件方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-07-07
  • python爬蟲 基于requests模塊的get請求實現(xiàn)詳解

    python爬蟲 基于requests模塊的get請求實現(xiàn)詳解

    這篇文章主要介紹了python爬蟲 基于requests模塊的get請求實現(xiàn)詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-08-08
  • Tensorflow使用Anaconda、pycharm安裝記錄

    Tensorflow使用Anaconda、pycharm安裝記錄

    這篇文章主要介紹了Tensorflow使用Anaconda、pycharm安裝記錄,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-07-07
  • Pandas?時間序列分析中的resample函數(shù)

    Pandas?時間序列分析中的resample函數(shù)

    這篇文章主要介紹了Pandas?時間序列分析中的resample函數(shù),Pandas?中的resample函數(shù)用于各種頻率的轉(zhuǎn)換工作,下面我們就來看看其的參數(shù)、相關(guān)資料等,需要的小伙伴可以參考一下,希望給你帶來幫助
    2022-02-02
  • Django網(wǎng)絡(luò)框架之創(chuàng)建虛擬開發(fā)環(huán)境操作示例

    Django網(wǎng)絡(luò)框架之創(chuàng)建虛擬開發(fā)環(huán)境操作示例

    這篇文章主要介紹了Django網(wǎng)絡(luò)框架之創(chuàng)建虛擬開發(fā)環(huán)境操作,簡單描述了虛擬開發(fā)環(huán)境的概念、功能,并分析了使用venv與virtualenv安裝虛擬環(huán)境相關(guān)操作技巧,需要的朋友可以參考下
    2019-06-06
  • 弄清Pytorch顯存的分配機(jī)制

    弄清Pytorch顯存的分配機(jī)制

    這篇文章主要介紹了Pytorch顯存的分配機(jī)制的相關(guān)資料,幫助大家更好的理解和使用Pytorch,感興趣的朋友可以了解下
    2020-12-12
  • python 3.5實現(xiàn)檢測路由器流量并寫入txt的方法實例

    python 3.5實現(xiàn)檢測路由器流量并寫入txt的方法實例

    這篇文章主要給大家介紹了關(guān)于利用python 3.5實現(xiàn)檢測路由器流量并寫入txt的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起看看吧。
    2017-12-12

最新評論