题目描述
设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。
实现 MinStack 类:
MinStack() 初始化堆栈对象。
void push(int val) 将元素val推入堆栈。
void pop() 删除堆栈顶部的元素。
int top() 获取堆栈顶部的元素。
int getMin() 获取堆栈中的最小元素。
示例 1:
["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++解答
GYL
看评论区好像这道题经常出现在面试题中,按照官方的思路是创建两个栈来完成任务,一个栈提供所有的数据进行入栈出栈和栈顶数据查找的功能,另一个栈提供最小元素查找的功能,由于有出入栈的操作,所以对于最小栈,入栈的是最小的元素,即当前数据和栈顶数据的最小值作为新元素入栈,这样能够保证入栈后出栈元素是最小值的话那就正常出栈,不是最小值的话不影响最小栈的查找;
但是这种思路其实可以说是作弊了,毕竟这道题是要模拟一个栈的操作,如果用栈来模拟栈的话,可能面试官并不会喜欢?
class MinStack { private: stack<int> stk; stack<int> minstk; public: MinStack() { minstk.push(INT_MAX); } void push(int val) { stk.push(val); minstk.push(min(minstk.top(),val)); } void pop() { stk.pop(); minstk.pop(); } int top() { return stk.top(); } int getMin() { return minstk.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(); */