亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Python實現(xiàn)棧和隊列的簡單操作方法示例

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

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

先簡單的了解一下數(shù)據(jù)結構里面的棧和堆:

棧和隊列是兩種基本的數(shù)據(jù)結構,同為容器類型。兩者根本的區(qū)別在于:

stack:后進先出

queue:先進先出

stack和queue是不能通過查詢具體某一個位置的元素而進行操作的。但是他們的排列是按順序的

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

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

class Stack(object):
  def __init__(self):
    self.stack = []
  def push(self, value):  # 進棧
    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]

我們定義如下的鏈表來實現(xiàn)隊列數(shù)據(jù)結構:

定義一個頭結點,左邊指向隊列的開頭,右邊指向隊列的末尾,這樣就可以保證我們插入一個元素和取出一個元素都是O(1)的操作,使用這種鏈表實現(xiàn)stack也是非常的方便。實現(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é)點
    self.head = Head()
  def enqueue(self, value):
    #插入一個元素
    newnode = Node(value)
    p = self.head
    if p.right:
      #如果head節(jié)點的右邊不為None
      #說明隊列中已經(jīng)有元素了
      #就執(zhí)行下列的操作
      temp = p.right
      p.right = newnode
      temp.next = newnode
    else:
      #這說明隊列為空,插入第一個元素
      p.right = newnode
      p.left = newnode
  def dequeue(self):
    #取出一個元素
    p = self.head
    if p.left and (p.left == p.right):
      #說明隊列中已經(jīng)有元素
      #但是這是最后一個元素
      temp = p.left
      p.left = p.right = None
      return temp.value
    elif p.left and (p.left != p.right):
      #說明隊列中有元素,而且不止一個
      temp = p.left
      p.left = temp.next
      return temp.value
    else:
      #說明隊列為空
      #拋出查詢錯誤
      raise LookupError('queue is empty!')
  def is_empty(self):
    if self.head.left:
      return False
    else:
      return True
  def top(self):
    #查詢目前隊列中最早入隊的元素
    if self.head.left:
      return self.head.left.value
    else:
      raise LookupError('queue is empty!')

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

希望本文所述對大家Python程序設計有所幫助。

相關文章

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

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

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

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

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

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

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

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

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

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

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

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

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

    OPCUA-Python實例

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

    Django admin組件的使用

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

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

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

    Python Flask框架使用介紹

    今天來給大家說一個Python的輕量級web開發(fā)框架——Flask,為什么要推薦它呢?當然是因為它夠輕量級了,開發(fā)迅速是它的特點,當然它也有缺點,不過這里不說,因為既用它又說它差感覺不好
    2022-08-08

最新評論