力扣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;
};

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/24581.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

光电管道液位传感器与电容式液位开关相比

如今&#xff0c;随着检测液位技术的不断发展&#xff0c;检测液位的方法也越来越多&#xff0c;比如浮球开关、电容式液位传感器、管道式液位传感器等等&#xff0c;那么光电管道液位传感器与电容式液位开关相比&#xff0c;有哪些优势&#xff1f; 光电管道液位传感器采用先…

论文高级图表绘制(Python语言,局部放大图)

本文将通过一个具体的示例,展示如何使用Python语言和Matplotlib库来绘制高级图表,包括局部放大图的制作。适用于多条曲线绘制在同一个图表中,但由于数据量过大,导致曲线的细节看不清,需要对细节进行局部放大。如下图: 环境准备 首先,确保你的Python环境中已经安装了以…

页面加载性能分析中,如何确定哪些资源是关键的,哪些可以延迟加载?

在页面加载性能分析中&#xff0c;确定哪些资源是关键的&#xff0c;哪些可以延迟加载&#xff0c;可以通过以下步骤进行&#xff1a; 使用 Performance 面板&#xff1a; 在 Chrome DevTools 的 Performance 面板中记录页面加载过程。分析记录结果&#xff0c;查看哪些资源加载…

基于SSM+Jsp的高校信息资源共享平台

开发语言&#xff1a;Java框架&#xff1a;ssm技术&#xff1a;JSPJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包…

页面加载性能分析时,有哪些常见的性能瓶颈需要特别注意?

在进行页面加载性能分析时&#xff0c;以下是一些常见的性能瓶颈&#xff0c;需要特别注意&#xff1a; 长页面加载时间&#xff1a; 页面加载时间超过行业标准或用户期望&#xff0c;导致用户流失。 高 CPU 使用率&#xff1a; 某些脚本或操作导致 CPU 使用率飙升&#xff0c;…

基于STM32开发的智能家居监控系统

目录 引言环境准备智能家居监控系统基础代码实现&#xff1a;实现智能家居监控系统 4.1 传感器数据读取4.2 电器设备控制4.3 实时数据监控与分析4.4 用户界面与数据可视化应用场景&#xff1a;家庭安全监控与管理问题解决方案与优化收尾与总结 1. 引言 随着智能家居技术的发…

C++的MQTT开发:使用Paho的C++接口实现消息发布、订阅、连接RabbitMQ

C Paho实现MQTT消息发布功能 要使用paho的cpp接口实现发布MQTT消息的功能&#xff0c;需要进行以下步骤&#xff1a; 安装paho库&#xff1a;首先从paho官方网站下载并安装paho的C库。可以从https://www.eclipse.org/paho/clients/cpp/ 下载适合操作系统的版本。 创建MQTT客户…

FM151A,FM171B和利时工控

FM151A,FM171B和利时工控&#xff0c;DCS系统应该具备以下特点&#xff1a;1.系统具备开放的体系结构&#xff0c;可以提供多层的开放数据接口&#xff1b;FM151A,FM171B和利时工控。2.系统应具备强大的处理功能&#xff0c;中型分布式控制系统大型数据采集监控系统功能。FM151…

[数据集][目标检测]室内积水检测数据集VOC+YOLO格式761张1类别

数据集格式&#xff1a;Pascal VOC格式YOLO格式(不包含分割路径的txt文件&#xff0c;仅仅包含jpg图片以及对应的VOC格式xml文件和yolo格式txt文件) 图片数量(jpg文件个数)&#xff1a;761 标注数量(xml文件个数)&#xff1a;761 标注数量(txt文件个数)&#xff1a;761 标注类别…

Spark Python环境搭建与优化:深入剖析四个方面、五个方面、六个方面及七个关键要点

Spark Python环境搭建与优化&#xff1a;深入剖析四个方面、五个方面、六个方面及七个关键要点 在大数据处理领域&#xff0c;Apache Spark凭借其出色的性能和灵活性备受瞩目。而要在Python中利用Spark的强大功能&#xff0c;首先需要搭建一个稳定且高效的Spark Python环境。本…

使用小黄鸟(HttpCanary)、VMOS Pro虚拟机对手机APP进行抓包(附带软件)

老规矩先看&#xff0c;效果图&#xff1a; 文章很详细&#xff0c;希望可以耐心看完&#xff0c;保证可以学会抓包&#xff0c;不再走冤枉路&#xff0c;小编在之前看过太多类似文章&#xff0c;折腾了太久才搞懂的&#xff0c;写这篇文章就是不想希望你们像小编一样再花时间…

C++ 20新特性之三向比较运算符

概述 在C中&#xff0c;如果需要对两个自定义类的对象进行比较&#xff0c;我们通常要单独定义6个比较运算符&#xff1a;、!、<、<、>、>。这不仅繁琐&#xff0c;还很容易出错&#xff0c;特别是当比较逻辑复杂时&#xff0c;稍有不慎就会引发不一致的比较结果。…

最新的ffmepg.js前端VUE3实现视频、音频裁剪上传功能

package.json "dependencies": {"ffmpeg/ffmpeg": "^0.12.10","ffmpeg/util": "^0.12.1" }vue3组件代码 根据需要更改 <script setup lang"ts"> import { FFmpeg } from ffmpeg/ffmpeg; import { fetchF…

mac无法读取windows分区怎么办 苹果硬盘怎么读取

对于Mac电脑用户但有Windows系统使用需求的&#xff0c;我们可以通过Boot Camp启动转换助理安装Windows分区这个方案来解决&#xff0c;不过因为两个系统的磁盘格式不同&#xff0c;相应的也会产生一些问题&#xff0c;例如无法正常读取windows分区。下面本文就详细说明mac无法…

在Java中使用SeleniumAPI,超详细

Java中 Selenium相关操作 1 定位元素 1.1 css选择器定位元素 就是定位到页面的元素&#xff0c;本质上就是一个一个的语法 下面举几个具体的例子&#xff1a; 类选择器 按照给定的 class 属性的值&#xff0c;选择所有匹配的元素。 语法&#xff1a;.classname 例子&am…

Sass详细介绍

Sass&#xff08;Syntactically Awesome Stylesheets&#xff09;是一种CSS预处理器&#xff0c;用于增强CSS的功能和灵活性。以下是对Sass的详细介绍&#xff0c;采用分点表示和归纳的方式&#xff1a; 1. Sass的概述 Sass是一种CSS预处理器&#xff0c;它扩展了CSS的语法和…

力扣1358.包含所有三种字符的子字符串数目

力扣1358.包含所有三种字符的子字符串数目 遍历左端点 找到最小的子字符串 res n - j(右边全部) class Solution {public:int numberOfSubstrings(string s) {unordered_map<char,int> cnt;int n s.size(),res0,count3;for(int i0,j0;j<n;j){if(!cnt.count(s[j])…

Python如何巧妙回应:深入解析Python的回应策略与技巧

Python如何巧妙回应&#xff1a;深入解析Python的回应策略与技巧 在编程的世界里&#xff0c;Python以其简洁、易读和强大的功能库赢得了众多开发者的青睐。然而&#xff0c;当我们与Python程序进行交互时&#xff0c;如何巧妙地回应其输出或错误信息&#xff0c;成为了提高编…

数字签名及其作用

一、技术难点 数字签名作为信息安全领域的关键技术之一&#xff0c;其技术难点主要体现在以下几个方面&#xff1a; 算法选择&#xff1a;不同的数字签名算法具有不同的安全性、效率和应用场景。如RSA、ECDSA、DSA等算法各有优劣&#xff0c;如何根据实际需求选择合适的算法是…

flutter 解析json另类封装方式 List<bean>,哈哈哈

flutter 解析json另类封装方式&#xff0c;哈哈哈 日常学习&#xff0c;仅供参考&#xff0c;不喜 勿喷 http请求数据泛型解析封装&#xff0c;需要判断泛型数据类型再根据类型解析&#xff0c;本文只抽取了list演示 核心代码 import dart:convert;import package:webwsyn/h…