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

img

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

尘觉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值