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

