当前位置:网站首页>[头条]笔试题——最小栈
[头条]笔试题——最小栈
2022-08-01 23:58:00 【陈亦康】


解法一:(相对解法二,会非常鸡肋)
思路:
- 由于获取堆栈最小元素时间复杂度为O(1),所有用创建一个变量min用来存放最小值
- 将存放最小值的变量min设为Integer.MAX_VALUE
- push方法里,每push一次用min比较
- 创建两个栈,第一个栈用来存放数据,第二栈用来通过变量第一个栈而得出最小数据的零时栈
class MinStack {
public Stack<Integer> stack;
public Stack<Integer> stackTmp;
public MinStack() {
stack = new Stack<>();
stackTmp = new Stack<>();
}
//先赋最大值
public int min = Integer.MAX_VALUE;
public void push(int val) {
//有比他小的就赋值
if(val < min){
min = val;
}
stack.push(val);
}
public void pop() {
if(stack.pop() == min){
//被pop后min需要重新赋值,依旧用最大值
min = Integer.MAX_VALUE;
//将所有元素转移到stackTmp,目的是为了让min重新与所有元素比较
while(!stack.empty()){
int tmp = stack.pop();
if(tmp < min){
min = tmp;
}
stackTmp.push(tmp);
}
//再转移到stack
while(!stackTmp.empty()){
stack.push(stackTmp.pop());
}
}
}
public int top() {
return stack.peek();
}
public int getMin() {
return min;
}
}解法二:(分析如下)



代码如下:
class MinStack {
Stack<Integer> stack;//普通栈
Stack<Integer> stackMin;//最小栈
public MinStack() {
stack = new Stack<>();
stackMin = new Stack<>();
}
//压栈
public void push(int val) {
//给最小站赋初值
if(stackMin.empty()){
stackMin.push(val);
}
//若不是初值,先判断是否小于等于(等于是以防pop后为空)最小栈栈顶元素,若是,才给最小栈压栈
else if(stackMin.peek() >= val){
stackMin.push(val);
}
stack.push(val);
}
public void pop() {
if((int)stackMin.peek() == (int)stack.peek()){
stackMin.pop();
}
stack.pop();
}
public int top() {
return stack.peek();
}
public int getMin() {
return stackMin.peek();
}
}
边栏推荐
猜你喜欢

Is TCP reliable?Why?

【Leetcode】1206. Design Skiplist

技术分享 | 接口测试中如何使用Json 来进行数据交互 ?

Use Jenkins for continuous integration, this knowledge point must be mastered

1个月写900多条用例,二线城市年薪33W+的测试经理能有多卷?

Flink Yarn Per Job - Yarn应用

Flink Yarn Per Job - CliFrontend

Quartus uses tcl files to quickly configure pins

Flink Yarn Per Job - 提交流程一

Excel文件读写(创建与解析)
随机推荐
Get piggy homestay (short-term rental) data
Excel导入和导出
类型“FC<Props>”的参数不能赋给类型“ForwardRefRenderFunction<unknown, Props>”的参数。 属性“defaultProps”的类型不兼容。 不
信息系统项目管理师必背核心考点(五十七)知识管理工具
一道golang中关于iota的面试题
正则表达式
【三子棋】C语言实现简易三子棋
2022 6th Strong Net Cup Part WP
很多人喜欢用多御安全浏览器,竟是因为这些原因
ansible模块--copy模块
使用Jenkins做持续集成,这个知识点必须要掌握
Flink Yarn Per Job - CliFrontend
YOLO等目标检测模型的非极大值抑制NMS和评价指标(Acc, Precision, Recall, AP, mAP, RoI)、YOLOv5中[email protected]与
Quartus 使用 tcl 文件快速配置管脚
@Transactional注解在类上还是接口上使用,哪种方式更好?
Flink学习第四天——完成第一个Flink 流批一体案例
【ACWing】230. 排列计数
软件测试之移动APP安全测试简析,北京第三方软件检测机构分享
Architecture basic concept and nature of architecture
solidity