LeetCode初級算法--設計問題02:最小棧

LeetCode初級算法--設計問題02:最小棧

搜索微信公眾號:'AI-ming3526'或者'計算機視覺這件小事' 獲取更多算法、機器學習干貨
csdn:https://blog.csdn.net/baidu_31657889/
csdn:https://blog.csdn.net/abcgkj/
github:https://github.com/aimi-cn/AILearners

一、引子

這是由LeetCode官方推出的的經(jīng)典面試題目清單~
這個模塊對應的是探索的初級算法~旨在幫助入門算法。我們第一遍刷的是leetcode推薦的題目。
查看完整的劍指Offer算法題解析請點擊github鏈接:
github地址

二讹开、題目

設計一個支持 push,pop,top 操作汹粤,并能在常數(shù)時間內(nèi)檢索到最小元素的棧。

  • push(x) -- 將元素 x 推入棧中田晚。
  • pop() -- 刪除棧頂?shù)脑亍?/li>
  • top() -- 獲取棧頂元素嘱兼。
  • getMin() -- 檢索棧中的最小元素。

示例:

MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin();   --> 返回 -3.
minStack.pop();
minStack.top();      --> 返回 0.
minStack.getMin();   --> 返回 -2.

1贤徒、思路

第一種方法:

用列表模擬棧芹壕,push、pop接奈、top和getMin分別對應list.append()踢涌、list.pop()、list[-1]和min()操作

第二種方法:

引入minStack列表存放最小值

2序宦、編程實現(xiàn)

第一種方法:

python

class MinStack(object):

    def __init__(self):
        """
        initialize your data structure here.
        """
        self.l = []
        

    def push(self, x):
        """
        :type x: int
        :rtype: None
        """
        if x is None:
            pass
        else:
            self.l.append(x)
        

    def pop(self):
        """
        :rtype: None
        """
        if self.l is None:
            return 'error'
        else:
            self.l.pop(-1)
        

    def top(self):
        """
        :rtype: int
        """
        if self.l is None:
            return 'error'
        else:
            return self.l[-1]
        

    def getMin(self):
        """
        :rtype: int
        """
        if self.l is None:
            return 'error'
        else:
            return min(self.l)


# Your MinStack object will be instantiated and called as such:
# obj = MinStack()
# obj.push(x)
# obj.pop()
# param_3 = obj.top()
# param_4 = obj.getMin()

第二種方法:

class MinStack(object):
 
    def __init__(self):
        """
        initialize your data structure here.
        """
        self.stack = []       #存放所有元素
        self.minStack = []#存放每一次壓入數(shù)據(jù)時睁壁,棧中的最小值(如果壓入數(shù)據(jù)的值大于棧中的最小值就不需要重復壓入最小值,小于或者等于棧中最小值則需要壓入)
 
    def push(self, x):
        """
        :type x: int
        :rtype: void
        """
        self.stack.append(x)
        if not self.minStack or self.minStack[-1]>=x:
            self.minStack.append(x)
 
    def pop(self):   #移除棧頂元素時互捌,判斷是否移除棧中最小值
        """
        :rtype: void
        """
        if self.minStack[-1]==self.stack[-1]:
            del self.minStack[-1]
        self.stack.pop()
 
    def top(self):
        """
        :rtype: int
        """
        return self.stack[-1]
        
    def getMin(self):
        """
        :rtype: int
        """
        return self.minStack[-1]

AIMI-CN AI學習交流群【1015286623】 獲取更多AI資料

分享技術潘明,樂享生活:我們的公眾號計算機視覺這件小事每周推送“AI”系列資訊類文章,歡迎您的關注秕噪!

本文由博客一文多發(fā)平臺 OpenWrite 發(fā)布钳降!

?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市巢价,隨后出現(xiàn)的幾起案子牲阁,更是在濱河造成了極大的恐慌固阁,老刑警劉巖,帶你破解...
    沈念sama閱讀 219,039評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件城菊,死亡現(xiàn)場離奇詭異备燃,居然都是意外死亡,警方通過查閱死者的電腦和手機凌唬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,426評論 3 395
  • 文/潘曉璐 我一進店門并齐,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人客税,你說我怎么就攤上這事况褪。” “怎么了更耻?”我有些...
    開封第一講書人閱讀 165,417評論 0 356
  • 文/不壞的土叔 我叫張陵测垛,是天一觀的道長。 經(jīng)常有香客問我秧均,道長食侮,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,868評論 1 295
  • 正文 為了忘掉前任目胡,我火速辦了婚禮锯七,結果婚禮上,老公的妹妹穿的比我還像新娘誉己。我一直安慰自己眉尸,他們只是感情好,可當我...
    茶點故事閱讀 67,892評論 6 392
  • 文/花漫 我一把揭開白布巨双。 她就那樣靜靜地躺著噪猾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪炉峰。 梳的紋絲不亂的頭發(fā)上畏妖,一...
    開封第一講書人閱讀 51,692評論 1 305
  • 那天,我揣著相機與錄音疼阔,去河邊找鬼戒劫。 笑死,一個胖子當著我的面吹牛婆廊,可吹牛的內(nèi)容都是我干的迅细。 我是一名探鬼主播,決...
    沈念sama閱讀 40,416評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼淘邻,長吁一口氣:“原來是場噩夢啊……” “哼茵典!你這毒婦竟也來了?” 一聲冷哼從身側響起宾舅,我...
    開封第一講書人閱讀 39,326評論 0 276
  • 序言:老撾萬榮一對情侶失蹤统阿,失蹤者是張志新(化名)和其女友劉穎彩倚,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扶平,經(jīng)...
    沈念sama閱讀 45,782評論 1 316
  • 正文 獨居荒郊野嶺守林人離奇死亡帆离,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,957評論 3 337
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了结澄。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片哥谷。...
    茶點故事閱讀 40,102評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖麻献,靈堂內(nèi)的尸體忽然破棺而出们妥,到底是詐尸還是另有隱情,我是刑警寧澤勉吻,帶...
    沈念sama閱讀 35,790評論 5 346
  • 正文 年R本政府宣布监婶,位于F島的核電站,受9級特大地震影響齿桃,放射性物質發(fā)生泄漏压储。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,442評論 3 331
  • 文/蒙蒙 一源譬、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧孕似,春花似錦踩娘、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,996評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至泛烙,卻和暖如春理卑,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背蔽氨。 一陣腳步聲響...
    開封第一講書人閱讀 33,113評論 1 272
  • 我被黑心中介騙來泰國打工藐唠, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人鹉究。 一個月前我還...
    沈念sama閱讀 48,332評論 3 373
  • 正文 我出身青樓宇立,卻偏偏與公主長得像,于是被迫代替她去往敵國和親自赔。 傳聞我的和親對象是個殘疾皇子妈嘹,可洞房花燭夜當晚...
    茶點故事閱讀 45,044評論 2 355

推薦閱讀更多精彩內(nèi)容