当前位置: 首页 > article >正文

【LeetCode】【算法】155. 最小栈

LeetCode 155. 最小栈

题目描述

设计一个支持 push ,pop ,top 操作,并能在常数时间内检索到最小元素的栈。
实现 MinStack 类:
MinStack() 初始化堆栈对象。
void push(int val) 将元素val推入堆栈。
void pop() 删除堆栈顶部的元素。
int top() 获取堆栈顶部的元素。
int getMin() 获取堆栈中的最小元素。

思路

思路:一个栈,栈内元素存储一个数组实现,其中第一个元素是存储元素值,第二个元素是存储的栈中元素最小值
第一步:定义队列:Deque<int[]> deque;
第二步:MinStack()初始化:deque = new ArrayDeque();
第三步:void push(int val),压入栈时判断需要存储的数组的第二个元素大小:① 如果栈为空,则deque.push(new int[]{val, val}); ② 如果栈不为空,如果deqeue.peek()[1]>val,则deque.push(new int[]{val, val}); 否则deque.push(new int[]{val,deque.peek()[1]});
第四步:void pop(),deque.pop()即可
第五步:int top(),return deque.peek()[0]即可
第六步:int getMin(),return deque.peek()[1]即可

代码

class MinStack {

    Deque<int[]> deque;

    public MinStack() {
        deque = new ArrayDeque<>();
    }

    public void push(int val) {
        if (deque.isEmpty()) {
            deque.push(new int[]{val, val});
        } else {
            int[] peek = deque.peek();
            if (peek[1] < val) {
                deque.push(new int[]{val, peek[1]});
            } else {
                deque.push(new int[]{val, val});
            }
        }
    }

    public void pop() {
        deque.pop();
    }

    public int top() {
        return deque.peek()[0];
    }

    public int getMin() {
        return deque.peek()[1];
    }
}

/**
 * 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();
 */

http://www.kler.cn/a/382778.html

相关文章:

  • Linux 文件的特殊权限—ACL项目练习
  • 【算法】算法大纲
  • 闲谭SpringBoot--ShardingSphere分库分表探究
  • nodejs的降级
  • WebRTC 在视频联网平台中的应用:开启实时通信新篇章
  • 009:传统计算机视觉之边缘检测
  • 常用查找算法count_if
  • 基于JavaWeb的宿舍管理系统的设计与实现
  • 【游戏引擎之路】登神长阶(十二)——DirectX11教程:If you‘re going through hell, keep going!
  • 英伟达的cuda和人工智能快车
  • ubuntu 22.04 server 安装 anaconda3
  • 【Zynq FPGA】基于 Zynq FPGA 的雷龙 SD NAND 测试
  • Java 8 Lambda 表达式和函数式接口的底层实现机制详解
  • 【Linux】【守护进程】总结整理
  • 【AI开源项目】FastGPT - 快速部署FastGPT以及使用知识库的两种方式!
  • hive表内外表之间切换
  • Docker 镜像拉不动?自建 Docker Hub 加速站 解决镜像拉取失败
  • 非凸科技助力第49届ICPC亚洲区域赛(成都)成功举办
  • ELK-ELK基本概念_ElasticSearch的配置
  • 立冬:冬日序曲的温柔启幕
  • Renesas R7FA8D1BH (Cortex®-M85) 存储空间介绍
  • 无人机之飞行管控平台篇
  • Linux查看端口占用及Windows查看端口占用
  • 电话语音机器人,是由哪些功能构成?
  • 通过Django 与 PostgreSQL 进行WEB开发详细流程
  • HTMLCSS:爱上班的猫咪