Python實(shí)現(xiàn)隊(duì)列的方法示例小結(jié)【數(shù)組,鏈表】
本文實(shí)例講述了Python實(shí)現(xiàn)隊(duì)列的方法。分享給大家供大家參考,具體如下:
Python實(shí)現(xiàn)隊(duì)列
隊(duì)列(FIFO),添加元素在隊(duì)列尾,刪除元素在隊(duì)列頭操作
- 列表實(shí)現(xiàn)隊(duì)列:利用python列表方法
代碼如下:
# 列表實(shí)現(xiàn)隊(duì)列 class listQueue(object): def __init__(self): self.items = [] def is_empty(self): return self.items == None def size(self): return len(self.items) # 入隊(duì) def enqueue(self, value): return self.items.append(value) # 出隊(duì) def dequeue(self): if self.is_empty(): raise Exception("queue is empty !") return self.items.pop(0)
- 鏈表實(shí)現(xiàn)隊(duì)列:
隊(duì)列的鏈表實(shí)現(xiàn)中,隊(duì)列的入隊(duì)(enqueue)操作類似于鏈表在表尾添加元素;隊(duì)列的出隊(duì)(dequeue)操作類似于在鏈表頭部刪除元素
隊(duì)列初始化中,定義兩個(gè)特殊節(jié)點(diǎn),隊(duì)列頭(head)和隊(duì)列尾(tail),方便進(jìn)行操作
代碼如下:
# 鏈表實(shí)現(xiàn)隊(duì)列 class linkedQueue(object): class Node(object): def __init__(self, value=None): self.value = value self.next = None def __init__(self): self.head = None self.tail = None #self.head.next = self.tail self.length = 0 def is_empty(self): return self.length == 0 def size(self): return self.length def enqueue(self, value): node = self.Node(value) if self.is_empty(): self.head = node else: self.tail.next = node self.tail = node self.length += 1 def dequeue(self): if self.is_empty(): raise Exception("queue is empty !") item = self.head.value self.head = self.head.next self.length -= 1 print("出隊(duì)列元素為:",item) return item link = linkedQueue() link.enqueue(1) link.enqueue(2) link.enqueue(3) link.enqueue(4) print("隊(duì)列長(zhǎng)度為:",link.size()) link.dequeue() link.dequeue()
運(yùn)行結(jié)果:
隊(duì)列長(zhǎng)度為: 4
出隊(duì)列元素為: 1
出隊(duì)列元素為: 2
更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門與進(jìn)階經(jīng)典教程》
希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。
- python線程優(yōu)先級(jí)隊(duì)列知識(shí)點(diǎn)總結(jié)
- 如何通過(guò)Python實(shí)現(xiàn)RabbitMQ延遲隊(duì)列
- python分布式爬蟲(chóng)中消息隊(duì)列知識(shí)點(diǎn)詳解
- Python通過(guò)隊(duì)列來(lái)實(shí)現(xiàn)進(jìn)程間通信的示例
- Python collections.deque雙邊隊(duì)列原理詳解
- 基于python實(shí)現(xiàn)操作redis及消息隊(duì)列
- Python Celery異步任務(wù)隊(duì)列使用方法解析
- Python實(shí)現(xiàn)一個(gè)優(yōu)先級(jí)隊(duì)列的方法
- Python如何使用隊(duì)列方式實(shí)現(xiàn)多線程爬蟲(chóng)
- Python多線程通信queue隊(duì)列用法實(shí)例分析
- python3 deque 雙向隊(duì)列創(chuàng)建與使用方法分析
- 詳解python數(shù)據(jù)結(jié)構(gòu)之隊(duì)列Queue
相關(guān)文章
django使用haystack調(diào)用Elasticsearch實(shí)現(xiàn)索引搜索
這篇文章主要介紹了django使用haystack調(diào)用Elasticsearch實(shí)現(xiàn)索引搜索,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07python plt.plot bar 如何設(shè)置繪圖尺寸大小
這篇文章主要介紹了python plt.plot bar 設(shè)置繪圖尺寸大小的操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-06-06Python中根據(jù)時(shí)間自動(dòng)創(chuàng)建文件夾的代碼實(shí)現(xiàn)
這篇文章主要介紹了Python中根據(jù)時(shí)間自動(dòng)創(chuàng)建文件夾的代碼實(shí)現(xiàn),這樣的話給工作帶來(lái)極大的便利,方便桌面文件按時(shí)間存放,具體實(shí)例代碼跟隨小編一起看看吧2021-10-10利用Python腳本在Nginx和uwsgi上部署MoinMoin的教程
這篇文章主要介紹了利用Python腳本在Nginx和uwsgi上部署MoinMoin的教程,示例基于CentOS操作系統(tǒng),需要的朋友可以參考下2015-05-05Python3使用Selenium獲取session和token方法詳解
這篇文章主要介紹了Python3使用Selenium獲取session和token方法詳解,需要的朋友可以參考下2021-02-02完美解決jupyter由于無(wú)法import新包的問(wèn)題
這篇文章主要介紹了完美解決jupyter由于無(wú)法import新包的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-05-05python中numpy包使用教程之?dāng)?shù)組和相關(guān)操作詳解
這篇文章主要給大家介紹了關(guān)于python中numpy包的使用教程,包含數(shù)組和相關(guān)操作等內(nèi)容,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)跟著小編一起學(xué)習(xí)學(xué)習(xí)吧。2017-07-07python實(shí)現(xiàn)大文本文件分割成多個(gè)小文件
這篇文章主要為大家詳細(xì)介紹了python實(shí)現(xiàn)大文本文件分割成多個(gè)小文件,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-04-04