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

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

你可能感兴趣的文章
DevExpress学习03——label控件的背景色问题
查看>>
Cass环境下光标无显示
查看>>
linux系统监控命令汇总
查看>>
谷歌:全球10大爬升最快搜索关键字排行榜 Google Zeitgeist 2011
查看>>
firewalld 极速上手指南
查看>>
纪念我人生中第一个merge into语句
查看>>
团队报告
查看>>
Linux下启动mongodb
查看>>
重温Android——调节屏幕亮度
查看>>
设计模式六大原则(1):单一职责原则
查看>>
当机器人具有自我知觉,并能自适应环境,真的不可怕吗?
查看>>
selenium环境搭建,浏览器驱动安装
查看>>
C# 递归函数详细介绍及使用方法
查看>>
web api 开发之 filter
查看>>
第十章:内核同步方法
查看>>
SQL中创建外键约束
查看>>
【网络编程】网络协议简析
查看>>
PHP 中Cookie和Session的使用
查看>>
Struts2注解
查看>>
Vue.js 判断对象属性是否存,不存在添加
查看>>