题目如下:
定义栈的数据结构,请在该类型中实现一个能够得到栈中所含最小元素的min函数(时间复杂度应为O(1))。
牛客网在线编程链接
思路:
- 因为题目要求时间复杂度为O(1),所以不能用遍历得出最小值的方法
- 创建两个栈,一个做正常操作,另一个用来记录最小值
- 入栈时正常栈入栈,min栈的栈顶元素与入栈值比较
- 如果min栈顶的值小于将要入栈的值,min栈将栈顶的值再次入栈
- 如果min栈顶的值大于将要入栈的值,min栈正常入栈
- 当正常栈出栈时min栈也要出栈,这样可以保持min栈栈顶一直是正常栈中的最小值
- 当要获取栈最小值时就peek() nim栈
题解
import java.util.Stack;
public class Solution {
Stack stack = new Stack();
Stack minStack = new Stack();
public void push(int node) {
if(stack.isEmpty()){
stack.push(node);
minStack.push(node);
}else{
if(node > (int)minStack.peek()){
stack.push(node);
minStack.push(minStack.peek());
}else{
stack.push(node);
minStack.push(node);
}
}
}
public int pop() {
minStack.pop();
return (int)stack.pop();
}
public int min() {
return (int)minStack.peek();
}
}
一种更省空间的思路:
在非当前栈中最小值入栈时nim栈不再入栈,在出栈时要判断正常栈栈顶值是否等于min栈栈顶值
如果:正常栈栈顶值等于min栈栈顶值,正常栈和min栈都出栈
如果:正常栈栈顶值不等于min栈栈顶值,正常栈出栈,min栈不出栈
本文介绍了一种使用两个栈来实现在O(1)时间复杂度内获取栈中最小元素的方法。通过维护一个普通栈进行常规操作,同时使用另一个栈专门记录最小值,确保在任何时刻都能快速找到最小元素。
201

被折叠的 条评论
为什么被折叠?



