算法的学习笔记—包含 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

相关文章

通俗易懂的Java常见限流算法具体实现

《通俗易懂的Java常见限流算法具体实现》:本文主要介绍Java常见限流算法具体实现的相关资料,包括漏桶算法、令牌桶算法、Nginx限流和Redis+Lua限流的实现原理和具体步骤,并比较了它们的... 目录一、漏桶算法1.漏桶算法的思想和原理2.具体实现二、令牌桶算法1.令牌桶算法流程:2.具体实现2.1

Python itertools中accumulate函数用法及使用运用详细讲解

《Pythonitertools中accumulate函数用法及使用运用详细讲解》:本文主要介绍Python的itertools库中的accumulate函数,该函数可以计算累积和或通过指定函数... 目录1.1前言:1.2定义:1.3衍生用法:1.3Leetcode的实际运用:总结 1.1前言:本文将详

Java深度学习库DJL实现Python的NumPy方式

《Java深度学习库DJL实现Python的NumPy方式》本文介绍了DJL库的背景和基本功能,包括NDArray的创建、数学运算、数据获取和设置等,同时,还展示了如何使用NDArray进行数据预处理... 目录1 NDArray 的背景介绍1.1 架构2 JavaDJL使用2.1 安装DJL2.2 基本操

轻松上手MYSQL之JSON函数实现高效数据查询与操作

《轻松上手MYSQL之JSON函数实现高效数据查询与操作》:本文主要介绍轻松上手MYSQL之JSON函数实现高效数据查询与操作的相关资料,MySQL提供了多个JSON函数,用于处理和查询JSON数... 目录一、jsON_EXTRACT 提取指定数据二、JSON_UNQUOTE 取消双引号三、JSON_KE

MySQL数据库函数之JSON_EXTRACT示例代码

《MySQL数据库函数之JSON_EXTRACT示例代码》:本文主要介绍MySQL数据库函数之JSON_EXTRACT的相关资料,JSON_EXTRACT()函数用于从JSON文档中提取值,支持对... 目录前言基本语法路径表达式示例示例 1: 提取简单值示例 2: 提取嵌套值示例 3: 提取数组中的值注意

Java function函数式接口的使用方法与实例

《Javafunction函数式接口的使用方法与实例》:本文主要介绍Javafunction函数式接口的使用方法与实例,函数式接口如一支未完成的诗篇,用Lambda表达式作韵脚,将代码的机械美感... 目录引言-当代码遇见诗性一、函数式接口的生物学解构1.1 函数式接口的基因密码1.2 六大核心接口的形态学

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

Oracle的to_date()函数详解

《Oracle的to_date()函数详解》Oracle的to_date()函数用于日期格式转换,需要注意Oracle中不区分大小写的MM和mm格式代码,应使用mi代替分钟,此外,Oracle还支持毫... 目录oracle的to_date()函数一.在使用Oracle的to_date函数来做日期转换二.日

C++11的函数包装器std::function使用示例

《C++11的函数包装器std::function使用示例》C++11引入的std::function是最常用的函数包装器,它可以存储任何可调用对象并提供统一的调用接口,以下是关于函数包装器的详细讲解... 目录一、std::function 的基本用法1. 基本语法二、如何使用 std::function

HarmonyOS学习(七)——UI(五)常用布局总结

自适应布局 1.1、线性布局(LinearLayout) 通过线性容器Row和Column实现线性布局。Column容器内的子组件按照垂直方向排列,Row组件中的子组件按照水平方向排列。 属性说明space通过space参数设置主轴上子组件的间距,达到各子组件在排列上的等间距效果alignItems设置子组件在交叉轴上的对齐方式,且在各类尺寸屏幕上表现一致,其中交叉轴为垂直时,取值为Vert