博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
力扣(LeetCode)155
阅读量:6691 次
发布时间:2019-06-25

本文共 1196 字,大约阅读时间需要 3 分钟。

题目地址:

题目描述:
设计一个支持 push,pop,top 操作,并能在常数时间内检索到最小元素的栈。

push(x) -- 将元素 x 推入栈中。

pop() -- 删除栈顶的元素。
top() -- 获取栈顶元素。
getMin() -- 检索栈中的最小元素。
示例:

MinStack minStack = new MinStack();

minStack.push(-2);
minStack.push(0);
minStack.push(-3);
minStack.getMin(); --> 返回 -3.
minStack.pop();
minStack.top(); --> 返回 0.
minStack.getMin(); --> 返回 -2.

解答:

每次入栈都放入两个元素,分别是当前元素,和当前的最小元素(因此放入之前需要和当前值进行比较)。

java ac代码:

class MinStack {    /** initialize your data structure here. */    int size;    int[]stack = new int[20000];    int min = Integer.MAX_VALUE;    public MinStack() {            }        public void push(int x) {        stack[size++] = x;        min = Math.min(x,min);        stack[size++] = min;    }        public void pop() {        if(size == 0)return;        size -= 2;        if(size == 0)        {            min = Integer.MAX_VALUE;            return;        }        min = stack[size-1];    }        public int top() {        return stack[size-2];    }        public int getMin() {        return min;    }}/** * Your MinStack object will be instantiated and called as such: * MinStack obj = new MinStack(); * obj.push(x); * obj.pop(); * int param_3 = obj.top(); * int param_4 = obj.getMin(); */

转载地址:http://agkoo.baihongyu.com/

你可能感兴趣的文章
2008 R2 证书服务器应用详解
查看>>
hive 动态分区太多问题
查看>>
Windows Server 2008 RemoteApp(二)---部署激活远程桌面授权服务器
查看>>
读取日志文件开发总结
查看>>
IOS --React Native
查看>>
Linux CPU
查看>>
用模板实现顺序表与单链表
查看>>
Linux/Centos ntp时间同步,联网情况和无网情况配置
查看>>
初级网络运维工程师比赛题目
查看>>
跨交换机实现vlan实验报告
查看>>
jquery easyui滚动条部分设置介绍
查看>>
cannot find -lxxx问题
查看>>
预防云端开源项目打包 Redis Labs再更改模块
查看>>
超惊人!去年发生的身分外泄安全事件是2017的4倍
查看>>
oracle sqlplus免安装的配置instantclient-basiclite
查看>>
Java开发GUI之选择列表
查看>>
一、分布式商城架构逻辑图
查看>>
机器人是如何完成避障的?机器人避障解决方案解读
查看>>
通过错误堆栈信息和源码分析错误来源
查看>>
C和C++ 读写文件速度问题
查看>>