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

首頁 > 編程 > Python > 正文

Python實現(xiàn)包含min函數(shù)的棧

2019-11-25 16:49:03
字體:
供稿:網(wǎng)友

本文實例講述了Python實現(xiàn)包含min函數(shù)的棧。分享給大家供大家參考,具體如下:

# coding=utf8'''題目:定義棧的數(shù)據(jù)結(jié)構(gòu),請在該類型中實現(xiàn)一個能夠得到棧的最小元素的min函數(shù)。在該棧中,調(diào)用min、push及pop的時間復雜度都是O(1)。'''class Stack():  def __init__(self):    self.main_stack = []    # 輔助棧,每次次最小的元素壓入輔助棧    self.assist_stack = []    # 記錄棧中的最小元素    self._min = None  def min(self):    return self._min  def push(self, data):    self.main_stack.append(data)    if self._min is None:      self._min = data    else:      if data < self._min:        self._min = data    # 將最小的元素壓入輔助棧    self.assist_stack.append(self._min)  def pop(self):    if len(self.main_stack) == 0:      raise Exception('no data')    elif len(self.main_stack) == 1:      self.assist_stack.pop()      self._min = None      return self.main_stack.pop()    else:      self.assist_stack.pop()      self._min = self.assist_stack[-1]      return self.main_stack.pop()if __name__ == '__main__':  s = Stack()  s.push(3)  s.push(4)  s.push(2)  s.push(1)  print s.min()  s.pop()  s.pop()  print s.min()  s.pop()  print s.min()  s.pop()  print s.min()  s.pop()

更多關(guān)于Python相關(guān)內(nèi)容可查看本站專題:《Python正則表達式用法總結(jié)》、《Python數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Python Socket編程技巧總結(jié)》、《Python函數(shù)使用技巧總結(jié)》、《Python字符串操作技巧匯總》、《Python入門與進階經(jīng)典教程》及《Python文件與目錄操作技巧匯總

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

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 乐昌市| 资源县| 吉木萨尔县| 齐齐哈尔市| 麟游县| 祁阳县| 曲周县| 新巴尔虎左旗| 石狮市| 呼图壁县| 广饶县| 隆昌县| 葵青区| 通江县| 苍梧县| 京山县| 白水县| 白沙| 大安市| 罗城| 弥勒县| 普宁市| 西林县| 崇州市| 东辽县| 开封市| 博爱县| 四川省| 营山县| 霸州市| 安宁市| 渭南市| 舒兰市| 成都市| 清水县| 同德县| 靖远县| 勐海县| 峡江县| 马山县| 靖州|