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

Python實(shí)現(xiàn)棧和隊(duì)列的簡(jiǎn)單操作方法示例

 更新時(shí)間:2019年11月29日 11:14:18   作者:LuckyQueen0928  
這篇文章主要介紹了Python實(shí)現(xiàn)棧和隊(duì)列的簡(jiǎn)單操作方法,結(jié)合實(shí)例形式詳細(xì)分析了Python棧和隊(duì)列的原理與簡(jiǎn)單實(shí)現(xiàn)技巧,需要的朋友可以參考下

本文實(shí)例講述了Python實(shí)現(xiàn)棧和隊(duì)列的簡(jiǎn)單操作方法。分享給大家供大家參考,具體如下:

先簡(jiǎn)單的了解一下數(shù)據(jù)結(jié)構(gòu)里面的棧和堆:

棧和隊(duì)列是兩種基本的數(shù)據(jù)結(jié)構(gòu),同為容器類(lèi)型。兩者根本的區(qū)別在于:

stack:后進(jìn)先出

queue:先進(jìn)先出

stack和queue是不能通過(guò)查詢(xún)具體某一個(gè)位置的元素而進(jìn)行操作的。但是他們的排列是按順序的

對(duì)于stack我們可以使用python內(nèi)置的list實(shí)現(xiàn),因?yàn)閘ist是屬于線性數(shù)組,在末尾插入和刪除一個(gè)元素所使用的時(shí)間都是O(1),這非常符合stack的要求。當(dāng)然,我們也可以使用鏈表來(lái)實(shí)現(xiàn)。

stack的實(shí)現(xiàn)代碼(使用python內(nèi)置的list),實(shí)現(xiàn)起來(lái)是非常的簡(jiǎn)單,就是list的一些常用操作

class Stack(object):
  def __init__(self):
    self.stack = []
  def push(self, value):  # 進(jìn)棧
    self.stack.append(value)
  def pop(self): #出棧
    if self.stack:
      self.stack.pop()
    else:
      raise LookupError('stack is empty!')
  def is_empty(self): # 如果棧為空
    return bool(self.stack)
  def top(self): 
    #取出目前stack中最新的元素
    return self.stack[-1]

我們定義如下的鏈表來(lái)實(shí)現(xiàn)隊(duì)列數(shù)據(jù)結(jié)構(gòu):

定義一個(gè)頭結(jié)點(diǎn),左邊指向隊(duì)列的開(kāi)頭,右邊指向隊(duì)列的末尾,這樣就可以保證我們插入一個(gè)元素和取出一個(gè)元素都是O(1)的操作,使用這種鏈表實(shí)現(xiàn)stack也是非常的方便。實(shí)現(xiàn)代碼如下:

class Head(object):
  def __init__(self):
    self.left = None
    self.right = None
class Node(object):
  def __init__(self, value):
    self.value = value
    self.next = None
class Queue(object):
  def __init__(self):
    #初始化節(jié)點(diǎn)
    self.head = Head()
  def enqueue(self, value):
    #插入一個(gè)元素
    newnode = Node(value)
    p = self.head
    if p.right:
      #如果head節(jié)點(diǎn)的右邊不為None
      #說(shuō)明隊(duì)列中已經(jīng)有元素了
      #就執(zhí)行下列的操作
      temp = p.right
      p.right = newnode
      temp.next = newnode
    else:
      #這說(shuō)明隊(duì)列為空,插入第一個(gè)元素
      p.right = newnode
      p.left = newnode
  def dequeue(self):
    #取出一個(gè)元素
    p = self.head
    if p.left and (p.left == p.right):
      #說(shuō)明隊(duì)列中已經(jīng)有元素
      #但是這是最后一個(gè)元素
      temp = p.left
      p.left = p.right = None
      return temp.value
    elif p.left and (p.left != p.right):
      #說(shuō)明隊(duì)列中有元素,而且不止一個(gè)
      temp = p.left
      p.left = temp.next
      return temp.value
    else:
      #說(shuō)明隊(duì)列為空
      #拋出查詢(xún)錯(cuò)誤
      raise LookupError('queue is empty!')
  def is_empty(self):
    if self.head.left:
      return False
    else:
      return True
  def top(self):
    #查詢(xún)目前隊(duì)列中最早入隊(duì)的元素
    if self.head.left:
      return self.head.left.value
    else:
      raise LookupError('queue is empty!')

更多關(guān)于Python相關(guān)內(nèi)容感興趣的讀者可查看本站專(zhuān)題:《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python加密解密算法與技巧總結(jié)》、《Python編碼操作技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》及《Python入門(mén)與進(jìn)階經(jīng)典教程

希望本文所述對(duì)大家Python程序設(shè)計(jì)有所幫助。

相關(guān)文章

  • Django實(shí)現(xiàn)帶進(jìn)度條的倒計(jì)時(shí)功能詳解

    Django實(shí)現(xiàn)帶進(jìn)度條的倒計(jì)時(shí)功能詳解

    這篇文章主要為大家詳細(xì)介紹了如何利用Django實(shí)現(xiàn)簡(jiǎn)單的帶進(jìn)度條的倒計(jì)時(shí)功能,可以在頁(yè)面加載后自動(dòng)開(kāi)始計(jì)時(shí),下次計(jì)時(shí)需要手動(dòng)刷新頁(yè)面,需要的可以參考一下
    2023-04-04
  • 利用python對(duì)excel中一列的時(shí)間數(shù)據(jù)更改格式操作

    利用python對(duì)excel中一列的時(shí)間數(shù)據(jù)更改格式操作

    這篇文章主要介紹了利用python對(duì)excel中一列的時(shí)間數(shù)據(jù)更改格式操作,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2020-07-07
  • python?gravis庫(kù)實(shí)現(xiàn)圖形數(shù)據(jù)可視化實(shí)例探索

    python?gravis庫(kù)實(shí)現(xiàn)圖形數(shù)據(jù)可視化實(shí)例探索

    這篇文章主要為大家介紹了python?gravis庫(kù)實(shí)現(xiàn)圖形數(shù)據(jù)可視化實(shí)例探索,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2024-02-02
  • 使用Python實(shí)現(xiàn)二分法查找的示例

    使用Python實(shí)現(xiàn)二分法查找的示例

    這篇文章主要介紹了使用Python實(shí)現(xiàn)二分法查找的示例,二分法通常又叫二分查找,一般用于查找一個(gè)有序數(shù)組中的某個(gè)值的位置或者給定的特定值的插入位置,需要的朋友可以參考下
    2023-04-04
  • Python3實(shí)現(xiàn)騰訊云OCR識(shí)別

    Python3實(shí)現(xiàn)騰訊云OCR識(shí)別

    這篇文章主要為大家詳細(xì)介紹了Python3實(shí)現(xiàn)騰訊云OCR識(shí)別,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • python 獲取字典鍵值對(duì)的實(shí)現(xiàn)

    python 獲取字典鍵值對(duì)的實(shí)現(xiàn)

    這篇文章主要介紹了python 獲取字典鍵值對(duì)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • OPCUA-Python實(shí)例

    OPCUA-Python實(shí)例

    這篇文章主要介紹了OPCUA-Python實(shí)例,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • Django admin組件的使用

    Django admin組件的使用

    這篇文章主要介紹了Django admin組件的使用,幫助大家更好的理解和學(xué)習(xí)Django框架,感興趣的朋友可以了解下
    2020-10-10
  • Python實(shí)現(xiàn)FM算法解析

    Python實(shí)現(xiàn)FM算法解析

    這篇文章主要介紹了Python實(shí)現(xiàn)FM算法解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-06-06
  • Python Flask框架使用介紹

    Python Flask框架使用介紹

    今天來(lái)給大家說(shuō)一個(gè)Python的輕量級(jí)web開(kāi)發(fā)框架——Flask,為什么要推薦它呢?當(dāng)然是因?yàn)樗鼔蜉p量級(jí)了,開(kāi)發(fā)迅速是它的特點(diǎn),當(dāng)然它也有缺點(diǎn),不過(guò)這里不說(shuō),因?yàn)榧扔盟终f(shuō)它差感覺(jué)不好
    2022-08-08

最新評(píng)論