栈的最小值提取
方法一:空间换时间,为保障时间复杂度为O(1)。因此加一个辅助站,与源栈同步,栈顶保存最小值。
代码如下:
class Solution { public: stack<int>normal,minval; void push(int value) { normal.push(value); if(minval.empty()) minval.push(value); else { if(value<minval.top()) minval.push(value); else minval.push(minval.top()); } } void pop() { normal.pop(); minval.pop(); } int top() { return normal.top(); } int min() { return minval.top(); } };