leet-code/src/main/java/leetcode/editor/cn/MinStack.java

139 lines
3.2 KiB
Java
Raw Normal View History

2021-03-31 15:33:29 +08:00
//设计一个支持 push pop top 操作,并能在常数时间内检索到最小元素的栈。
//
//
// push(x) —— 将元素 x 推入栈中。
// pop() —— 删除栈顶的元素。
// top() —— 获取栈顶元素。
// getMin() —— 检索栈中的最小元素。
//
//
//
//
// 示例:
//
// 输入:
//["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.
//
//
//
//
// 提示:
//
//
// pop、top 和 getMin 操作总是在 非空栈 上调用。
//
// Related Topics 栈 设计
// 👍 856 👎 0
package leetcode.editor.cn;
import java.util.Stack;
//155:最小栈
public class MinStack {
public static void main(String[] args) {
//测试代码
// Solution solution = new MinStack1().new Solution();
2021-03-31 15:33:29 +08:00
}
//力扣代码
//leetcode submit region begin(Prohibit modification and deletion)
class MinStack1 {
// Stack<Integer> stack;
// Stack<Integer> min;
// public MinStack() {
// stack = new Stack<>();
// min = new Stack<>();
// }
// public void push(int val) {
// if (stack.isEmpty()) {
// min.push(val);
// } else {
// min.push(Math.min(min.peek(),val));
// }
// stack.push(val);
// }
// public void pop() {
// stack.pop();
// min.pop();
// }
// public int top() {
// return stack.peek();
// }
// public int getMin() {
// return min.peek();
// }
class Data{
int num;
int min;
public Data(int num, int min) {
this.num = num;
this.min = min;
}
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
public int getMin() {
return min;
}
public void setMin(int min) {
this.min = min;
}
}
Stack<Data> stack;
public MinStack1() {
2021-03-31 15:33:29 +08:00
stack = new Stack<>();
}
2021-03-31 15:33:29 +08:00
public void push(int val) {
if (stack.isEmpty()) {
stack.push(new Data(val,val));
2021-03-31 15:33:29 +08:00
} else {
stack.push(new Data(val,Math.min(val,stack.peek().min)));
2021-03-31 15:33:29 +08:00
}
}
2021-03-31 15:33:29 +08:00
public void pop() {
stack.pop();
}
2021-03-31 15:33:29 +08:00
public int top() {
return stack.peek().num;
2021-03-31 15:33:29 +08:00
}
2021-03-31 15:33:29 +08:00
public int getMin() {
return stack.peek().min;
2021-03-31 15:33:29 +08:00
}
}
/**
* 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();
*/
//leetcode submit region end(Prohibit modification and deletion)
}