C++怎么获取最小栈

本篇内容介绍了“C++怎么获取最小栈”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!

最小栈

Design a stack that supports push, pop, top, and retrieving the minimum element in constant time.

C++怎么获取最小栈

  • push(x) -- Push element x onto stack.

  • pop() -- Removes the element on top of the stack.

  • top() -- Get the top element.

  • getMin() -- Retrieve the minimum element in the stack.

Example:

MinStack minStack = new MinStack();minStack.push(-2);minStack.push(0);minStack.push(-3);minStack.getMin(); --> Returns -3.minStack.pop();minStack.top(); --> Returns 0.minStack.getMin(); --> Returns -2.

这道最小栈跟原来的栈相比就是多了一个功能,可以返回该栈的最小值。使用两个栈来实现,一个栈来按顺序存储 push 进来的数据,另一个用来存出现过的最小值。代码如下:

C++ 解法一:

classMinStack{
public:
MinStack(){}
voidpush(intx){
s1.push(x);
if(s2.empty()||x<=s2.top())s2.push(x);
}
voidpop(){
if(s1.top()==s2.top())s2.pop();
s1.pop();
}
inttop(){
returns1.top();
}
intgetMin(){
returns2.top();
}

private:
stack<int>s1,s2;
};

Java 解法一:

publicclassMinStack{
privateStack<Integer>s1=newStack<>();
privateStack<Integer>s2=newStack<>();

publicMinStack(){}
publicvoidpush(intx){
s1.push(x);
if(s2.isEmpty()||s2.peek()>=x)s2.push(x);
}
publicvoidpop(){
intx=s1.pop();
if(s2.peek()==x)s2.pop();
}
publicinttop(){
returns1.peek();
}
publicintgetMin(){
returns2.peek();
}
}

需要注意的是上面的 Java 解法中的 pop() 中,为什么不能用注释掉那两行的写法,博主之前也不太明白为啥不能对两个 stack 同时调用 peek() 函数来比较,如果是这种写法,那么不管 s1 和 s2 对栈顶元素是否相等,永远返回 false。这是为什么呢,这就要看 Java 对于peek的定义了,对于 peek() 函数的返回值并不是 int 类型,而是一个 Object 类型,这是一个基本的对象类型,如果直接用双等号 == 来比较的话,肯定不会返回 true,因为是两个不同的对象,所以一定要先将一个转为 int 型,然后再和另一个进行比较,这样才能得到想要的答案,这也是 Java 和 C++ 的一个重要的不同点吧。

那么下面再来看另一种解法,这种解法只用到了一个栈,还需要一个整型变量 min_val 来记录当前最小值,初始化为整型最大值,然后如果需要进栈的数字小于等于当前最小值 min_val,则将 min_val 压入栈,并且将 min_val 更新为当前数字。在出栈操作时,先将栈顶元素移出栈,再判断该元素是否和 min_val 相等,相等的话将 min_val 更新为新栈顶元素,再将新栈顶元素移出栈即可,参见代码如下:

C++ 解法二:

classMinStack{
public:
MinStack(){
min_val=INT_MAX;
}
voidpush(intx){
if(x<=min_val){
st.push(min_val);
min_val=x;
}
st.push(x);
}
voidpop(){
intt=st.top();st.pop();
if(t==min_val){
min_val=st.top();st.pop();
}
}
inttop(){
returnst.top();
}
intgetMin(){
returnmin_val;
}
private:
intmin_val;
stack<int>st;
};

Java 解法二:

publicclassMinStack{
privateintmin_val=Integer.MAX_VALUE;
privateStack<Integer>s=newStack<>();

publicMinStack(){}
publicvoidpush(intx){
if(x<=min_val){
s.push(min_val);
min_val=x;
}
s.push(x);
}
publicvoidpop(){
if(s.pop()==min_val)min_val=s.pop();
}
publicinttop(){
returns.peek();
}
publicintgetMin(){
returnmin_val;
}
}

“C++怎么获取最小栈”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注恰卡编程网网站,小编将为大家输出更多高质量的实用文章!

发布于 2021-07-29 22:00:54
收藏
分享
海报
0 条评论
179
上一篇:css3中transform属性详细介绍 下一篇:C++实现寻找旋转有序数组的最小值的方法
目录

    0 条评论

    本站已关闭游客评论,请登录或者注册后再评论吧~

    忘记密码?

    图形验证码