算法的学习笔记—包含 min 函数的栈(牛客JZ30)

2024-08-20 16:12

本文主要是介绍算法的学习笔记—包含 min 函数的栈(牛客JZ30),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

img

😀前言
在日常编程中,栈是一种常见的数据结构,具有后进先出的特点。它支持基本的操作如 push(入栈)、pop(出栈)和 top(获取栈顶元素)。然而,当需要在栈中快速获取最小值时,这就成为了一个具有挑战性的任务。本文将介绍如何实现一个支持 min 函数的栈数据结构,并提供代码示例。

🏠个人主页:尘觉主页

文章目录

  • 😀包含 min 函数的栈
    • 题目链接
    • 🥰问题描述
    • 😊解决思路
    • 😁代码实现
      • 🤗示例分析
    • 😄总结

😀包含 min 函数的栈

题目链接

牛客网

🥰问题描述

我们需要实现一个栈结构,除了常规的栈操作外,还需要支持 min 函数,能够在 O(1) 的时间复杂度内返回栈中最小的元素。要求如下:

  • push(value): 将 value 压入栈中。
  • pop(): 弹出栈顶元素。
  • top(): 获取栈顶元素。
  • min(): 获取栈中最小元素。

所有操作都需要在常数时间内完成。我们可以通过维护一个额外的栈来解决这个问题。

😊解决思路

为了实现上述功能,我们可以使用两个栈:

  1. 数据栈 (dataStack): 用于存储所有的元素。
  2. 最小栈 (minStack): 用于存储当前栈中的最小值。

具体操作如下:

  • Push 操作:
    • 将元素压入数据栈中。
    • 比较当前元素与最小栈栈顶的元素,将两者中较小的元素压入最小栈。
  • Pop 操作:
    • 同时弹出数据栈和最小栈的栈顶元素。
  • Top 操作:
    • 返回数据栈的栈顶元素。
  • Min 操作:
    • 返回最小栈的栈顶元素。

通过这种方式,minStack 的栈顶元素始终是当前数据栈中的最小值,从而保证 min 函数在 O(1) 时间内获取最小元素。

😁代码实现

以下是基于上述思路的 Java 实现:

import java.util.Stack;public class MinStack {private Stack<Integer> dataStack = new Stack<>();private Stack<Integer> minStack = new Stack<>();/*** 将一个元素推入栈中* @param node 元素值*/public void push(int node) {dataStack.push(node);if (minStack.isEmpty() || node <= minStack.peek()) {minStack.push(node);} else {minStack.push(minStack.peek());}}/*** 弹出栈顶元素*/public void pop() {dataStack.pop();minStack.pop();}/*** 获取栈顶元素* @return 栈顶元素*/public int top() {return dataStack.peek();}/*** 获取栈中的最小元素* @return 最小元素*/public int min() {return minStack.peek();}
}

🤗示例分析

假设我们进行如下操作序列:

假设我们进行如下操作序列:

String[] operations = {"PSH-1","PSH2","MIN","TOP","POP","PSH1","TOP","MIN"};

解释如下:

  1. PSH-1: 将 -1 压入栈中。此时栈中元素为 [-1],最小栈也为 [-1]
  2. PSH2: 将 2 压入栈中。此时栈中元素为 [2, -1],最小栈为 [-1, -1](因为 -1 是最小值)。
  3. MIN: 获取当前最小值,即最小栈的栈顶元素 -1。
  4. TOP: 获取栈顶元素,即 2。
  5. POP: 弹出栈顶元素,栈中元素变为 [-1],最小栈为 [-1]
  6. PSH1: 将 1 压入栈中。此时栈中元素为 [1, -1],最小栈为 [-1, -1](因为 -1 仍是最小值)。
  7. TOP: 获取栈顶元素,即 1。
  8. MIN: 获取当前最小值,即最小栈的栈顶元素 -1。

😄总结

通过维护一个额外的最小栈,我们可以在 O(1) 的时间复杂度内获取栈中最小值,且所有操作的空间复杂度为 O(n)。这种方法不仅简单易实现,而且高效,适用于各种需要快速获取最小值的场景。希望这篇文章能帮助你更好地理解和实现包含最小函数的栈数据结构。

😁热门专栏推荐
想学习vue的可以看看这个

java基础合集

数据库合集

redis合集

nginx合集

linux合集

手写机制

微服务组件

spring_尘觉

springMVC

mybits

等等等还有许多优秀的合集在主页等着大家的光顾感谢大家的支持

🤔欢迎大家加入我的社区 尘觉社区

文章到这里就结束了,如果有什么疑问的地方请指出,诸佬们一起来评论区一起讨论😁
希望能和诸佬们一起努力,今后我们一起观看感谢您的阅读🍻
如果帮助到您不妨3连支持一下,创造不易您们的支持是我的动力🤞

img

这篇关于算法的学习笔记—包含 min 函数的栈(牛客JZ30)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

重新对Java的类加载器的学习方式

《重新对Java的类加载器的学习方式》:本文主要介绍重新对Java的类加载器的学习方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、介绍1.1、简介1.2、符号引用和直接引用1、符号引用2、直接引用3、符号转直接的过程2、加载流程3、类加载的分类3.1、显示

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ

Kotlin运算符重载函数及作用场景

《Kotlin运算符重载函数及作用场景》在Kotlin里,运算符重载函数允许为自定义类型重新定义现有的运算符(如+-…)行为,从而让自定义类型能像内置类型那样使用运算符,本文给大家介绍Kotlin运算... 目录基本语法作用场景类对象数据类型接口注意事项在 Kotlin 里,运算符重载函数允许为自定义类型重

Pandas中统计汇总可视化函数plot()的使用

《Pandas中统计汇总可视化函数plot()的使用》Pandas提供了许多强大的数据处理和分析功能,其中plot()函数就是其可视化功能的一个重要组成部分,本文主要介绍了Pandas中统计汇总可视化... 目录一、plot()函数简介二、plot()函数的基本用法三、plot()函数的参数详解四、使用pl

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Python的time模块一些常用功能(各种与时间相关的函数)

《Python的time模块一些常用功能(各种与时间相关的函数)》Python的time模块提供了各种与时间相关的函数,包括获取当前时间、处理时间间隔、执行时间测量等,:本文主要介绍Python的... 目录1. 获取当前时间2. 时间格式化3. 延时执行4. 时间戳运算5. 计算代码执行时间6. 转换为指

Python正则表达式语法及re模块中的常用函数详解

《Python正则表达式语法及re模块中的常用函数详解》这篇文章主要给大家介绍了关于Python正则表达式语法及re模块中常用函数的相关资料,正则表达式是一种强大的字符串处理工具,可以用于匹配、切分、... 目录概念、作用和步骤语法re模块中的常用函数总结 概念、作用和步骤概念: 本身也是一个字符串,其中

shell编程之函数与数组的使用详解

《shell编程之函数与数组的使用详解》:本文主要介绍shell编程之函数与数组的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录shell函数函数的用法俩个数求和系统资源监控并报警函数函数变量的作用范围函数的参数递归函数shell数组获取数组的长度读取某下的

openCV中KNN算法的实现

《openCV中KNN算法的实现》KNN算法是一种简单且常用的分类算法,本文主要介绍了openCV中KNN算法的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录KNN算法流程使用OpenCV实现KNNOpenCV 是一个开源的跨平台计算机视觉库,它提供了各