91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Python實現棧和隊列的簡單操作方法示例

發布時間:2020-10-19 23:31:57 來源:腳本之家 閱讀:152 作者:LuckyQueen0928 欄目:開發技術

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

先簡單的了解一下數據結構里面的棧和堆:

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

stack:后進先出

Python實現棧和隊列的簡單操作方法示例

queue:先進先出

Python實現棧和隊列的簡單操作方法示例

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

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

stack的實現代碼(使用python內置的list),實現起來是非常的簡單,就是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]

我們定義如下的鏈表來實現隊列數據結構:

Python實現棧和隊列的簡單操作方法示例

定義一個頭結點,左邊指向隊列的開頭,右邊指向隊列的末尾,這樣就可以保證我們插入一個元素和取出一個元素都是O(1)的操作,使用這種鏈表實現stack也是非常的方便。實現代碼如下:

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):
    #初始化節點
    self.head = Head()
  def enqueue(self, value):
    #插入一個元素
    newnode = Node(value)
    p = self.head
    if p.right:
      #如果head節點的右邊不為None
      #說明隊列中已經有元素了
      #就執行下列的操作
      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):
      #說明隊列中已經有元素
      #但是這是最后一個元素
      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相關內容感興趣的讀者可查看本站專題:《Python數據結構與算法教程》、《Python加密解密算法與技巧總結》、《Python編碼操作技巧總結》、《Python函數使用技巧總結》、《Python字符串操作技巧匯總》及《Python入門與進階經典教程》

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

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

台南县| 惠州市| 舞钢市| 惠安县| 海丰县| 博兴县| 邹平县| 和田县| 康定县| 普宁市| 江西省| 镇坪县| 兰考县| 临沧市| 三河市| 谢通门县| 略阳县| 曲周县| 扶沟县| 尼玛县| 阳曲县| 新巴尔虎左旗| 曲麻莱县| 张北县| 苏尼特右旗| 阆中市| 盐亭县| 张家界市| 奉节县| 大余县| 嫩江县| 内丘县| 外汇| 夏河县| 固始县| 长子县| 大竹县| 舒城县| 西宁市| 旌德县| 汉源县|