手把手帶你了解C++最小棧
設(shè)計一個支持 push ,pop ,top 操作,并能在常數(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++支持的棧(原生棧),可以實現(xiàn) push、pop、top(peek), 但是要獲取最小元素, 一種方法是通過暴力搜索,從頭到尾遍歷整個,那么時間復雜度是 O(n),不是在常數(shù)級獲取最小值, 不符合題目的要求。
我們可以設(shè)置兩個棧,一個數(shù)據(jù)棧 datastack,用于存放需要存放的數(shù)據(jù),一個記錄最小值的棧 sortedstack。

每次 push 操作之后, 保存當前 push 元素之后數(shù)據(jù)棧中的最小值, 因為從第一次 push 到之后的每次 push 操作,我們知道每次 push 的值,也很容易知道當前的棧中的最小值。

```cpp
class MinStack {
public:
/** initialize your data structure here. */
//創(chuàng)建兩個棧
stack<int> datastack; //數(shù)據(jù)棧
stack<int> sortedstack; //有序棧,棧底最大,棧頂最小,有<=棧頂?shù)脑夭舙ush
MinStack() {
}
void push(int val) {
datastack.push(val); //將值push到數(shù)據(jù)棧
//有序棧
//當有序棧為空 或 值小于等于有序棧的棧頂 就push
if(sortedstack.empty()||val<=sortedstack.top()) //sortedstack==sortedstack.empty() 錯誤
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),包括多種操作,本篇只介紹插入,排序(遍歷),和刪除操作,重點是刪除操作比較復雜2022-04-04
C++實現(xiàn)LeetCode(76.最小窗口子串)
這篇文章主要介紹了C++實現(xiàn)LeetCode(76.最小窗口子串),本篇文章通過簡要的案例,講解了該項技術(shù)的了解與使用,以下就是詳細內(nèi)容,需要的朋友可以參考下2021-07-07
C語言實現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計
這篇文章主要為大家詳細介紹了C語言實現(xiàn)酒店客房管理系統(tǒng)課程設(shè)計,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2022-03-03
Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows)
Clion2020增加了很多新特性,修復了大量bug,大大提高了開發(fā)效率。這篇文章主要介紹了Clion2020.2.x最新激活碼破解版附安裝教程(Mac Linux Windows),需要的朋友可以參考下2020-11-11

