手把手帶你了解C++最小棧
設(shè)計(jì)一個(gè)支持 push ,pop ,top 操作,并能在常數(shù)時(shí)間內(nèi)檢索到最小元素的棧。
push(x)
—— 將元素 x 推入棧中。
pop()
—— 刪除棧頂?shù)脑亍?br />
top()
—— 獲取棧頂元素。
getMin()
—— 檢索棧中的最小元素。
示例:
輸入:
[“MinStack”,“push”,“push”,“push”,“getMin”,“pop”,“top”,“getMin”]
[[],[-2],[0],[-3],[],[],[],[]]
輸出:
[null,null,null,null,-3,null,0,-2]
解釋:
MinStack minStack = new MinStack();
minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.
思路
C++支持的棧(原生棧),可以實(shí)現(xiàn) push、pop、top(peek), 但是要獲取最小元素, 一種方法是通過暴力搜索,從頭到尾遍歷整個(gè),那么時(shí)間復(fù)雜度是 O(n),不是在常數(shù)級(jí)獲取最小值, 不符合題目的要求。
我們可以設(shè)置兩個(gè)棧,一個(gè)數(shù)據(jù)棧 datastack,用于存放需要存放的數(shù)據(jù),一個(gè)記錄最小值的棧 sortedstack。
每次 push 操作之后, 保存當(dāng)前 push 元素之后數(shù)據(jù)棧中的最小值, 因?yàn)閺牡谝淮?push 到之后的每次 push 操作,我們知道每次 push 的值,也很容易知道當(dāng)前的棧中的最小值。
```cpp class MinStack { public: /** initialize your data structure here. */ //創(chuàng)建兩個(gè)棧 stack<int> datastack; //數(shù)據(jù)棧 stack<int> sortedstack; //有序棧,棧底最大,棧頂最小,有<=棧頂?shù)脑夭舙ush MinStack() { } void push(int val) { datastack.push(val); //將值push到數(shù)據(jù)棧 //有序棧 //當(dāng)有序棧為空 或 值小于等于有序棧的棧頂 就push if(sortedstack.empty()||val<=sortedstack.top()) //sortedstack==sortedstack.empty() 錯(cuò)誤 sortedstack.push(val); } void pop() { if(datastack.top()==sortedstack.top()) //數(shù)據(jù)棧的棧頂 和 有序棧的棧頂 相同, 有序棧出棧 sortedstack.pop(); datastack.pop(); //數(shù)據(jù)棧一直在出棧 } int top() { return datastack.top(); } int getMin() { return sortedstack.top(); } }; /** * Your MinStack object will be instantiated and called as such: * MinStack* obj = new MinStack(); * obj->push(val); * obj->pop(); * int param_3 = obj->top(); * int param_4 = obj->getMin(); */
總結(jié)
本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關(guān)注腳本之家的更多內(nèi)容!
相關(guān)文章
C++ 詳解數(shù)據(jù)結(jié)構(gòu)中的搜索二叉樹
搜索二叉樹是一種具有良好排序和查找性能的二叉樹數(shù)據(jù)結(jié)構(gòu),包括多種操作,本篇只介紹插入,排序(遍歷),和刪除操作,重點(diǎn)是刪除操作比較復(fù)雜2022-04-04C++實(shí)現(xiàn)LeetCode(76.最小窗口子串)
這篇文章主要介紹了C++實(shí)現(xiàn)LeetCode(76.最小窗口子串),本篇文章通過簡要的案例,講解了該項(xiàng)技術(shù)的了解與使用,以下就是詳細(xì)內(nèi)容,需要的朋友可以參考下2021-07-07C語言實(shí)現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計(jì)
這篇文章主要為大家詳細(xì)介紹了C語言實(shí)現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計(jì),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-03-03Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows)
Clion2020增加了很多新特性,修復(fù)了大量bug,大大提高了開發(fā)效率。這篇文章主要介紹了Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows),需要的朋友可以參考下2020-11-11