定義棧的資料結構,請在該型別中實現乙個能夠得到棧的最小元素的 min 函式在該棧中,呼叫 min、push 及 pop 的時間複雜度都是 o(1)。
示例:
minstack minstack =
newminstack()
;minstack.
push(-
2);minstack.
push(0
);minstack.
push(-
3);minstack.
min();
--> 返回 -
3.minstack.
pop();
minstack.
top();
--> 返回 0.
minstack.
min();
--> 返回 -
2.
各函式的呼叫總次數不超過 20000 次
雙棧解法
思路:定義乙個儲存棧a和乙個輔助棧b,儲存棧a的作用儲存是將所有的數,輔助棧b的作用是儲存乙個最小值的序列,其入棧出棧規則如下:
當棧b為空或者入棧的數小於等於棧b的棧頂元素,則入棧;
當棧a出棧的元素與棧b棧頂元素一樣,則出棧;
min函式即返回棧b的棧頂元素即可。
class
minstack
void
push
(int x)
}void
pop(
)int
top(
)int
min()}
;/**
* your minstack object will be instantiated and called as such:
* minstack* obj = new minstack();
* obj->push(x);
* obj->pop();
* int param_3 = obj->top();
* int param_4 = obj->min();
*/
劍指offer 包含min函式的棧
一 問題描述 二 思路 兩個棧,乙個當前棧data,乙個輔助棧m min,輔助棧用來儲存當前的最小值,如果出棧,輔助棧也出棧,棧頂元素始終是當前的最小值。在入棧時,如果輔助棧為空或者當前值小於輔助棧棧頂元素,則將當前值加入輔助棧 否則將輔助棧的棧頂元素加入輔助棧,表明此次有大於min棧頂數字入棧。以...
劍指offer 包含min函式的棧
題目描述 定義棧的資料結構,請在該型別中實現乙個能夠得到棧最小元素的min函式。這個題要求時間複雜度是o 1 竟然想了好久沒想出來,原來思維定式了,一直在想既然要從小到大排序怎麼可能實現o 1 呢 其實由於出棧入棧是由順序的,用來記錄最小值的棧也不用完整記錄所有元素的順序,只要根據入棧的順序來就行 ...
劍指offer 包含min函式的棧
定義棧的資料結構,請在該型別中實現乙個能夠得到棧最小元素的min函式。思路 這裡,定義兩個棧,stack和min stack,其中,min stack的最後乙個數永遠保持是stack中最小的乙個數。具體的,在puch時,只儲存比當前最小的還要小的數。pop時,如果stack最小的數pop出,min ...