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

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

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

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

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

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

循壞隊(duì)列

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

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

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

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

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

接下來我們給隊(duì)列增加一些操作:

判空

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

清空隊(duì)列

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)隊(duì)列類就定義好了,如果你看過介紹隊(duì)列的文章,就會發(fā)現(xiàn)循環(huán)隊(duì)列和普通隊(duì)列的操作在邏輯上還是有一些相似的。

總結(jié)

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

相關(guān)文章

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

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

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

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

    在數(shù)據(jù)可視化中曲線圖是一種常見的展示數(shù)據(jù)趨勢的方式,Python作為一種強(qiáng)大的編程語言,提供了豐富的數(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項(xiàng)目步驟詳解

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

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

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

    selenium最初是一個(gè)自動化測試工具,而爬蟲中使用它主要是為了解決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í)行其他維護(hù)任務(wù),本文給大家介紹的非常詳細(xì),需要的朋友參考下
    2023-06-06
  • 基于Python實(shí)現(xiàn)炸彈人小游戲

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

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

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

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

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

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

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

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

最新評論