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

本文共 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://dwvfm.baihongyu.com/

你可能感兴趣的文章
最小生成树的一些证明
查看>>
第一次发布
查看>>
PHP 错误记录1
查看>>
关于MongoDB分布式高可用集群实现
查看>>
虚方法、隐藏方法、抽象方法、密封方法、派生类中访问基类成员
查看>>
[WinForm]Dundas Chart控件学习(附源码)
查看>>
数字处理类
查看>>
EasyUI
查看>>
ubuntu16.04 Cmake学习二
查看>>
在linux系统中I/O 调度的选择
查看>>
NOIP2016模拟 星际争霸(二分)
查看>>
css-背景类样式
查看>>
java多线程
查看>>
关于一点儿对仓储(Repository)的理解
查看>>
renren_login_urllib带Cookie
查看>>
处理数据时该注意的
查看>>
在QTableView中某列中添加Button的导致滚动条滚动的时候消失的问题
查看>>
python初探-collections容器数据类型
查看>>
迷宫~哈哈~终于懂了BFS
查看>>
java的命名方法
查看>>