国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開發(fā) > Python > 正文

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

2024-09-09 19:03:02
字體:
供稿:網(wǎng)友

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

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

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

stack:后進(jìn)先出

queue:先進(jìn)先出

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

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

stack的實(shí)現(xiàn)代碼(使用python內(nèi)置的list),實(shí)現(xiàn)起來是非常的簡(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]

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

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

class Head(object):  def __init__(self):    self.left = None    self.right = Noneclass Node(object):  def __init__(self, value):    self.value = value    self.next = Noneclass 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      #說明隊(duì)列中已經(jīng)有元素了      #就執(zhí)行下列的操作      temp = p.right      p.right = newnode      temp.next = newnode    else:      #這說明隊(duì)列為空,插入第一個(gè)元素      p.right = newnode      p.left = newnode  def dequeue(self):    #取出一個(gè)元素    p = self.head    if p.left and (p.left == p.right):      #說明隊(duì)列中已經(jīng)有元素      #但是這是最后一個(gè)元素      temp = p.left      p.left = p.right = None      return temp.value    elif p.left and (p.left != p.right):      #說明隊(duì)列中有元素,而且不止一個(gè)      temp = p.left      p.left = temp.next      return temp.value    else:      #說明隊(duì)列為空      #拋出查詢錯(cuò)誤      raise LookupError('queue is empty!')  def is_empty(self):    if self.head.left:      return False    else:      return True  def top(self):    #查詢目前隊(duì)列中最早入隊(duì)的元素    if self.head.left:      return self.head.left.value    else:      raise LookupError('queue is empty!')

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

發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 楚雄市| 新泰市| 大理市| 厦门市| 闸北区| 砚山县| 澄迈县| 乌拉特前旗| 武隆县| 大名县| 将乐县| 图片| 霍林郭勒市| 东阿县| 海阳市| 安徽省| 八宿县| 临洮县| 安新县| 天水市| 贡嘎县| 望奎县| 岳池县| 包头市| 长沙县| 南木林县| 仪征市| 乐安县| 乌什县| 当雄县| 米脂县| 安塞县| 仙游县| 高台县| 南宁市| 磴口县| 大名县| 若羌县| 子长县| 遂溪县| 庆安县|