手把手帶你了解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++多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換
最近在C++編程中經(jīng)常遇到需要多字節(jié)字符與寬字節(jié)字符相互轉(zhuǎn)換的問題,自己寫了一個類來封裝wchar_t與char類型間的轉(zhuǎn)換2012-11-11
關(guān)于數(shù)組做函數(shù)參數(shù)的問題集合匯總
本文是對關(guān)于數(shù)組做函數(shù)參數(shù)的問題進行了詳細的匯總,需要的朋友可以過來參考下。希望對大家有所幫助2013-10-10
C++11中初始化列表initializer lists的使用方法
C++11引入了初始化列表來初始化變量和對象,自定義類型,如果想用初始化列表就要包含initializer_list頭文件2021-09-09
C++踩坑實戰(zhàn)之構(gòu)造和析構(gòu)函數(shù)
不論是構(gòu)造函數(shù),還是析構(gòu)函數(shù),都是C++、C#語言相對于其他語言而言特殊的地方,它是為了方便類中對象的初始化,這篇文章主要給大家介紹了關(guān)于C++踩坑實戰(zhàn)之構(gòu)造和析構(gòu)函數(shù)的相關(guān)資料,需要的朋友可以參考下2021-07-07

