力扣hot100:155. 最小栈(栈,辅助栈存储相关信息)

2024-06-08 13:04

本文主要是介绍力扣hot100:155. 最小栈(栈,辅助栈存储相关信息),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

LeetCode:155. 最小栈
在这里插入图片描述

1、尝试单调栈

看到这题说,要常数时间内检索最小元素的栈,想到了单调栈,递增单调栈确实能维护最小值,但是这个最小值是存在一定意义的,即如果后面出现了最小值,那么前面的之前的最小值就会无效。

而本题存在弹出操作,这导致当前最小值可能会被丢弃,而需要使用之前的最小值,单调栈可能无法做到找回次小值。

能够弹出值且能一直保持维护数据的最小值的数据结构,是优先队列。因此我们改用优先队列实现。

2、栈+优先队列

如果想要常数级检索到最小元素 且 存在弹出元素,那么需要自定义优先队列,这时在弹出时时间复杂度会高一些。如果不自定义,那就需要延迟出队,这样虽然获取最小值时时间复杂度为高一些,但是弹出时间比较小。

  • 时间复杂度: O ( n l o g n ) O(nlogn) O(nlogn),堆排序的时间复杂度
  • 空间复杂度: O ( n ) O(n) O(n)
    在这里插入图片描述
class MinStack {
public:MinStack() {}void push(int val) {sta.push(val);nums[val]++;minSta.push(val);}void pop() {int num = sta.top();sta.pop();if(--nums[num] == 0) nums.erase(num);}int top() {return sta.top();}int getMin() {while(nums.count(minSta.top()) == 0) minSta.pop();return minSta.top();}
private:stack<int> sta;priority_queue<int, vector<int>, greater<int>> minSta;unordered_map<int, int> nums;
};

3、辅助栈

方法二,我们使用优先队列实时维护最小值,有必要吗?

要是我们直接使用一个栈为每一个元素维护一个以它为栈顶的栈的最小值,那是不是就OK了?
在这里插入图片描述
即:只要栈顶元素确定了,那么栈中当前的最小值也必然是唯一确定的。我们只需要维护一个元素时最小值的栈就行。

  • 时间复杂度: O ( n ) O(n) O(n),插入只需压栈两次,pop只需弹栈两次,查询是 O ( 1 ) O(1) O(1)
  • 空间复杂度: O ( n ) O(n) O(n)
    在这里插入图片描述
class MinStack {
public:MinStack() {min_sta.push(INT_MAX);//这个只是为了方便后面压入少一个条件判断}void push(int val) {sta.push(val);min_sta.push(min(min_sta.top(),val));}void pop() {sta.pop();min_sta.pop();}int top() {return sta.top();}int getMin() {return min_sta.top();}
private:stack<int> sta;stack<int> min_sta;
};

这篇关于力扣hot100:155. 最小栈(栈,辅助栈存储相关信息)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1042265

相关文章

Python如何实现PDF隐私信息检测

《Python如何实现PDF隐私信息检测》随着越来越多的个人信息以电子形式存储和传输,确保这些信息的安全至关重要,本文将介绍如何使用Python检测PDF文件中的隐私信息,需要的可以参考下... 目录项目背景技术栈代码解析功能说明运行结php果在当今,数据隐私保护变得尤为重要。随着越来越多的个人信息以电子形

Redis存储的列表分页和检索的实现方法

《Redis存储的列表分页和检索的实现方法》在Redis中,列表(List)是一种有序的数据结构,通常用于存储一系列元素,由于列表是有序的,可以通过索引来访问元素,因此可以很方便地实现分页和检索功能,... 目录一、Redis 列表的基本操作二、分页实现三、检索实现3.1 方法 1:客户端过滤3.2 方法

Redis的Zset类型及相关命令详细讲解

《Redis的Zset类型及相关命令详细讲解》:本文主要介绍Redis的Zset类型及相关命令的相关资料,有序集合Zset是一种Redis数据结构,它类似于集合Set,但每个元素都有一个关联的分数... 目录Zset简介ZADDZCARDZCOUNTZRANGEZREVRANGEZRANGEBYSCOREZ

C++中使用vector存储并遍历数据的基本步骤

《C++中使用vector存储并遍历数据的基本步骤》C++标准模板库(STL)提供了多种容器类型,包括顺序容器、关联容器、无序关联容器和容器适配器,每种容器都有其特定的用途和特性,:本文主要介绍C... 目录(1)容器及简要描述‌php顺序容器‌‌关联容器‌‌无序关联容器‌(基于哈希表):‌容器适配器‌:(

C#实现系统信息监控与获取功能

《C#实现系统信息监控与获取功能》在C#开发的众多应用场景中,获取系统信息以及监控用户操作有着广泛的用途,比如在系统性能优化工具中,需要实时读取CPU、GPU资源信息,本文将详细介绍如何使用C#来实现... 目录前言一、C# 监控键盘1. 原理与实现思路2. 代码实现二、读取 CPU、GPU 资源信息1.

使用MongoDB进行数据存储的操作流程

《使用MongoDB进行数据存储的操作流程》在现代应用开发中,数据存储是一个至关重要的部分,随着数据量的增大和复杂性的增加,传统的关系型数据库有时难以应对高并发和大数据量的处理需求,MongoDB作为... 目录什么是MongoDB?MongoDB的优势使用MongoDB进行数据存储1. 安装MongoDB

在C#中获取端口号与系统信息的高效实践

《在C#中获取端口号与系统信息的高效实践》在现代软件开发中,尤其是系统管理、运维、监控和性能优化等场景中,了解计算机硬件和网络的状态至关重要,C#作为一种广泛应用的编程语言,提供了丰富的API来帮助开... 目录引言1. 获取端口号信息1.1 获取活动的 TCP 和 UDP 连接说明:应用场景:2. 获取硬

Linux使用fdisk进行磁盘的相关操作

《Linux使用fdisk进行磁盘的相关操作》fdisk命令是Linux中用于管理磁盘分区的强大文本实用程序,这篇文章主要为大家详细介绍了如何使用fdisk进行磁盘的相关操作,需要的可以了解下... 目录简介基本语法示例用法列出所有分区查看指定磁盘的区分管理指定的磁盘进入交互式模式创建一个新的分区删除一个存

SpringBoot使用Apache Tika检测敏感信息

《SpringBoot使用ApacheTika检测敏感信息》ApacheTika是一个功能强大的内容分析工具,它能够从多种文件格式中提取文本、元数据以及其他结构化信息,下面我们来看看如何使用Ap... 目录Tika 主要特性1. 多格式支持2. 自动文件类型检测3. 文本和元数据提取4. 支持 OCR(光学

关于Maven生命周期相关命令演示

《关于Maven生命周期相关命令演示》Maven的生命周期分为Clean、Default和Site三个主要阶段,每个阶段包含多个关键步骤,如清理、编译、测试、打包等,通过执行相应的Maven命令,可以... 目录1. Maven 生命周期概述1.1 Clean Lifecycle1.2 Default Li