LeetCode-155.最小棧

題目描述 [最小棧]

設(shè)計(jì)一個(gè)支持 push,pop,top 操作碘裕,并能在常數(shù)時(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.

解題思路

轉(zhuǎn)自 https://www.cnblogs.com/jlxuexijidi-2015/p/4946223.html

用一個(gè)輔助棧來(lái)實(shí)現(xiàn)最小值的更新工作不撑。

這個(gè)輔助棧工作原理:

  • 入棧時(shí)文兢,1)當(dāng)數(shù)據(jù)棧為空時(shí),進(jìn)入棧的元素同時(shí)也進(jìn)入輔助棧燎孟;2)當(dāng)它不為空時(shí)禽作,就把該入棧元素與輔助棧的棧頂元素進(jìn)行比較尸昧,若入棧元素小揩页,則該元素同時(shí)也進(jìn)入輔助棧;若不是烹俗,則對(duì)輔助棧不進(jìn)行操作

  • 出棧時(shí)爆侣,1)當(dāng)時(shí)輔助棧的棧頂元素等于處理數(shù)據(jù)的數(shù)據(jù)棧棧頂元素時(shí),不經(jīng)數(shù)據(jù)棧要彈出元素幢妄,輔助棧也要彈出棧頂元素兔仰,2)當(dāng)不等時(shí),只對(duì)數(shù)據(jù)棧進(jìn)行出棧操作蕉鸳。

  • min函數(shù)只需返回輔助棧的棧頂源乎赴。

代碼

class MinStack {
public:
    /** initialize your data structure here. */
    MinStack() {}

    void push(int x) {
        s1.push(x);
        if (s2.empty() || x <= s2.top()) s2.push(x);
    }

    void pop() {
        if (s1.top() == s2.top()) s2.pop();
        s1.pop();
    }

    int top() {
        return s1.top();
    }

    int getMin() {
        return s2.top();
    }

private:
    stack<int> s1, s2;
};
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末忍法,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子榕吼,更是在濱河造成了極大的恐慌饿序,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,122評(píng)論 6 505
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件羹蚣,死亡現(xiàn)場(chǎng)離奇詭異原探,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)顽素,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,070評(píng)論 3 395
  • 文/潘曉璐 我一進(jìn)店門咽弦,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人胁出,你說(shuō)我怎么就攤上這事型型。” “怎么了划鸽?”我有些...
    開封第一講書人閱讀 164,491評(píng)論 0 354
  • 文/不壞的土叔 我叫張陵输莺,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我裸诽,道長(zhǎng)嫂用,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,636評(píng)論 1 293
  • 正文 為了忘掉前任丈冬,我火速辦了婚禮嘱函,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘埂蕊。我一直安慰自己往弓,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,676評(píng)論 6 392
  • 文/花漫 我一把揭開白布蓄氧。 她就那樣靜靜地躺著函似,像睡著了一般。 火紅的嫁衣襯著肌膚如雪喉童。 梳的紋絲不亂的頭發(fā)上撇寞,一...
    開封第一講書人閱讀 51,541評(píng)論 1 305
  • 那天,我揣著相機(jī)與錄音堂氯,去河邊找鬼蔑担。 笑死,一個(gè)胖子當(dāng)著我的面吹牛咽白,可吹牛的內(nèi)容都是我干的啤握。 我是一名探鬼主播,決...
    沈念sama閱讀 40,292評(píng)論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼晶框,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼排抬!你這毒婦竟也來(lái)了懂从?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,211評(píng)論 0 276
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤蹲蒲,失蹤者是張志新(化名)和其女友劉穎莫绣,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體悠鞍,經(jīng)...
    沈念sama閱讀 45,655評(píng)論 1 314
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡对室,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,846評(píng)論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了咖祭。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片掩宜。...
    茶點(diǎn)故事閱讀 39,965評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖么翰,靈堂內(nèi)的尸體忽然破棺而出牺汤,到底是詐尸還是另有隱情,我是刑警寧澤浩嫌,帶...
    沈念sama閱讀 35,684評(píng)論 5 347
  • 正文 年R本政府宣布檐迟,位于F島的核電站,受9級(jí)特大地震影響码耐,放射性物質(zhì)發(fā)生泄漏追迟。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,295評(píng)論 3 329
  • 文/蒙蒙 一骚腥、第九天 我趴在偏房一處隱蔽的房頂上張望敦间。 院中可真熱鬧,春花似錦束铭、人聲如沸廓块。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,894評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)带猴。三九已至,卻和暖如春懈万,著一層夾襖步出監(jiān)牢的瞬間拴清,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,012評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工钞速, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贷掖,地道東北人嫡秕。 一個(gè)月前我還...
    沈念sama閱讀 48,126評(píng)論 3 370
  • 正文 我出身青樓渴语,卻偏偏與公主長(zhǎng)得像,于是被迫代替她去往敵國(guó)和親昆咽。 傳聞我的和親對(duì)象是個(gè)殘疾皇子驾凶,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,914評(píng)論 2 355

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

  • 題目描述 設(shè)計(jì)一個(gè)支持 push牙甫,pop,top 操作调违,并能在常數(shù)時(shí)間內(nèi)檢索到最小元素的棧窟哺。 push(x) --...
    云胡同學(xué)閱讀 309評(píng)論 0 0
  • 原題地址 設(shè)置一個(gè)單調(diào)棧,每次看要壓入棧的元素是否比單調(diào)棧中的頂端值小技肩,如果小那就同時(shí)壓入到單調(diào)棧中且轨,彈出的時(shí)候,...
    鬼鬼812閱讀 127評(píng)論 0 1
  • 目錄 基本性質(zhì) 棧和隊(duì)列的基本操作 雙端隊(duì)列和優(yōu)先級(jí)隊(duì)列 深度優(yōu)先遍歷(DFS)和廣度優(yōu)先遍歷(BFS) 遞歸函數(shù)...
    kirito_song閱讀 797評(píng)論 0 6
  • 棧(stack)是限定僅在表尾進(jìn)行插入和刪除操作的線性表虚婿。隊(duì)列(queue)是一種先進(jìn)先出(First In Fi...
    innovatorCL閱讀 661評(píng)論 0 0
  • 無(wú)題 每一夜的睡去 每一晨的醒來(lái) 每一步的相同 每一刻的時(shí)間 每每一個(gè)人的孤獨(dú) 寂寞成了漫天大海 飛鳥不來(lái)旋奢,這片松...
    PoYee閱讀 230評(píng)論 0 0