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

Python 實現(xiàn)數(shù)據(jù)結(jié)構(gòu)-循環(huán)隊列的操作方法

 更新時間:2019年07月17日 09:53:32   作者:浩然haoran  
這篇文章主要介紹了Python 實現(xiàn)數(shù)據(jù)結(jié)構(gòu)-循環(huán)隊列的操作方法,需要的朋友可以參考下

今天我們來到了循環(huán)隊列這一節(jié),之前的文章中,我介紹過了用python自帶的列表來實現(xiàn)隊列,這是最簡單的實現(xiàn)方法。

但是,我們都知道,在列表中刪除第一個元素和刪除最后一個元素花費的時間代價是不一樣的,刪除列表的第一個元素,那么在它之后的所有元素都要進行移動。所以當(dāng)列表特別長的時候,這個代價就比較明顯了。我們本文介紹的循環(huán)隊列可以避免這個問題,同樣我們上篇文章提到的用鏈表實現(xiàn)的方法也可以避免。

下面,我們來介紹循環(huán)隊列。

循壞隊列

循環(huán)隊列,就是將普通的隊列首尾連接起來, 形成一個環(huán)狀,并分別設(shè)置首尾指針,用來指明隊列的頭和尾。每當(dāng)我們插入一個元素,尾指針就向后移動一位,當(dāng)然,在這里我們隊列的最大長度是提前定義好的,當(dāng)我們彈出一個元素,頭指針就向后移動一位。

這樣,列表中就不存在刪除操作,只有修改操作,從而避免了刪除前面節(jié)點造成的代價大的問題。

好,話不多說,我們用代碼來實現(xiàn)一下

class Loopqueue:
 def __init__(self, length):
  self.head = 0
  self.tail = 0
  self.maxSize = length
  self.cnt = 0
  self.__list = [None]*length

這里同樣,我們定義一個隊列類,在實例化循環(huán)隊列的時候,要求指定隊列的大小,除了首尾指針以及隊列最大長度之外,我們還聲明一個表示隊列當(dāng)前長度的屬性cnt。

接下來我們給隊列增加一些操作:

判空

def isEmpty(self):
  return self.cnt == 0

判滿

def isFull(self):
  return self.cnt == self.maxSize

添加元素

def push(self, data):
  if self.isFull():
   return False
  if self.isEmpty():
   self.__list[0] = data
   self.head = 0
   self.tail = 0
   self.cnt = 1
   return True
  self.tail = (self.tail+1)%self.maxSize
  self.cnt += 1
  self.__list[self.tail] = data
  return True

彈出元素

def pop(self):
  if self.isEmpty():
   return False
  data = self.__list[self.head]
  self.head = (self.head+1)%self.maxSize
  self.cnt -= 1
  return data

清空隊列

def clear(self):
  self.head = 0
  self.tail = 0
  self.cnt = 0
  return True

定義len和print函數(shù)

def __len__(self):
  return self.cnt

 def __str__(self):
  s = ''
  for i in range(self.cnt):
   index = (i + self.head) % self.maxSize
   s += str(self.__list[index])+' '
  return s

OK,我們的循環(huán)隊列類就定義好了,如果你看過介紹隊列的文章,就會發(fā)現(xiàn)循環(huán)隊列和普通隊列的操作在邏輯上還是有一些相似的。

總結(jié)

以上所述是小編給大家介紹的Python 實現(xiàn)數(shù)據(jù)結(jié)構(gòu)-循環(huán)隊列的操作方法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
如果你覺得本文對你有幫助,歡迎轉(zhuǎn)載,煩請注明出處,謝謝!

相關(guān)文章

  • python高斯分布概率密度函數(shù)的使用詳解

    python高斯分布概率密度函數(shù)的使用詳解

    今天小編就為大家分享一篇python高斯分布概率密度函數(shù)的使用詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • 如何使用python的plot繪制loss、acc曲線并存儲成圖片

    如何使用python的plot繪制loss、acc曲線并存儲成圖片

    在數(shù)據(jù)可視化中曲線圖是一種常見的展示數(shù)據(jù)趨勢的方式,Python作為一種強大的編程語言,提供了豐富的數(shù)據(jù)處理和可視化庫,使得繪制曲線圖變得非常簡單,下面這篇文章主要給大家介紹了關(guān)于如何使用python的plot繪制loss、acc曲線并存儲成圖片的相關(guān)資料,需要的朋友可以參考下
    2024-03-03
  • python list轉(zhuǎn)dict示例分享

    python list轉(zhuǎn)dict示例分享

    這篇文章主要介紹了python list轉(zhuǎn)dict的使用方法,大家參考使用吧
    2014-01-01
  • eclipse創(chuàng)建python項目步驟詳解

    eclipse創(chuàng)建python項目步驟詳解

    在本篇內(nèi)容里小編給大家分享了關(guān)于eclipse創(chuàng)建python項目的具體步驟和方法,需要的朋友們跟著學(xué)習(xí)下。
    2019-05-05
  • Python爬蟲基礎(chǔ)初探selenium

    Python爬蟲基礎(chǔ)初探selenium

    selenium最初是一個自動化測試工具,而爬蟲中使用它主要是為了解決requests無法執(zhí)行javaScript代碼的問題。本文給大家分享Python爬蟲基礎(chǔ)selenium知識,包括selenium工作原理,感興趣的朋友跟隨小編一起看看吧
    2021-05-05
  • 如何使用 python查詢Amazon DynamoDB

    如何使用 python查詢Amazon DynamoDB

    本文介紹了如何使用Python Boto3在Amazon DynamoDB上查詢DynamoDB 表、創(chuàng)建、列出和執(zhí)行其他 CRUD 活動以及執(zhí)行其他維護任務(wù),本文給大家介紹的非常詳細,需要的朋友參考下
    2023-06-06
  • 基于Python實現(xiàn)炸彈人小游戲

    基于Python實現(xiàn)炸彈人小游戲

    這篇文章主要介紹了基于Python中的Pygame模塊實現(xiàn)的炸彈人小游戲,文中的示例代碼講解詳細,對學(xué)習(xí)Python有一定的幫助,感興趣的小伙伴可以學(xué)習(xí)一下
    2021-12-12
  • 使用django的objects.filter()方法匹配多個關(guān)鍵字的方法

    使用django的objects.filter()方法匹配多個關(guān)鍵字的方法

    今天小編就為大家分享一篇使用django的objects.filter()方法匹配多個關(guān)鍵字的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-07-07
  • Python3 中把txt數(shù)據(jù)文件讀入到矩陣中的方法

    Python3 中把txt數(shù)據(jù)文件讀入到矩陣中的方法

    下面小編就為大家分享一篇Python3 中把txt數(shù)據(jù)文件讀入到矩陣中的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-04-04
  • python實現(xiàn)帶驗證碼網(wǎng)站的自動登陸實現(xiàn)代碼

    python實現(xiàn)帶驗證碼網(wǎng)站的自動登陸實現(xiàn)代碼

    本例所登錄的某網(wǎng)站需要提供用戶名,密碼和驗證碼,在此使用了python的urllib2直接登錄網(wǎng)站并處理網(wǎng)站的Cookie
    2015-01-01

最新評論