单调栈---神奇的栈

news2024/9/23 17:20:55

我们平时用的栈多,但是我们一般用的是什么呢?用来做有效的括号匹配?还是用来记录我们的二叉树的节点?

通过对栈的理解,我们学习一个新的概念–单调栈。所谓单调栈,就是单调递增或者单调递减的栈。

那么单调栈有什么作用呢?我们先看一个例题:

例题1

image.png
力扣:739. 每日温度
题目我们大致了解过了,我们开始做这个题,我们的思路如下:

  1. 题目的描述是,我们要找比第i个数大的下一个数,和如果没有比i大的下一个数。
  2. 如果找到了,我们要计算大多少,两个数的下标m,n相差多少。
  3. 相差的值就是结果数组中对应的值。
    我们先写一个简单的步骤:
 public int[] dailyTemperatures(int[] temperatures) {
        int[] arr = new int[temperatures.length];
       	//....
        return arr;
    }

首先这肯定是我们要写的,不过中间该怎么写?这个问题怎么分析?当然我们可以两个for循环使劲暴力,这个方法往往是很有效的,但是这个题数组的长度是105,暴力的话时间复杂度为O(n2),跑一会应该也能过,但是面试的时候面试官就该让你回去等通知了。所以我们现在就介绍单调栈的写法,时间复杂度为O(n):

  • 首先我们定一个栈,让在栈内数都是单调的,至于递增或者递减我们稍后再确定
  • 我们根据题意,如果没有比第i天气温高的,那么arr[i]=0
  • 如果有,我们就要记录相隔多久,那么就是两个天数的下标的差
    对于这个题而言,单调栈递增或递减影响不大,我们实现的方式不同罢了,我们用一个单调递减的模拟:
  • 定义一个栈,让他记录下标
  • 单调递减的时候,栈内的数据应该是这样:[75,71,69] (栈顶),那么当下一个比栈顶大的天气出现时,我们只需要减去两个下标的差,然后给栈顶元素下标赋值给arr数组对应的那天就行。

代码实现:

public int[] dailyTemperatures(int[] temperatures) {
        int[] arr = new int[temperatures.length];
	//定义单调栈,记录下标
        Deque<Integer> stack = new ArrayDeque<>();
	//将第一个下标放进,我们从第二天开始
        stack.push(0);
        for(int i = 1;i<arr.length;i++){
		//如果栈不为空,并且当前天气比栈顶高,那么我们将栈顶出栈
            while(!stack.isEmpty() && temperatures[i] > temperatures[stack.peek()]){
		//栈顶气温的下标
                int t = stack.pop();
		//找到了比他大的,那么结果数组的第t天的值就是两个下标的差
                arr[t] = i - t;
            }
	    //将当前结果入栈
            stack.push(i);
        }
        return arr;
    }

对于例1:temperatures = [73,74,75,71,69,72,76,73] ,len = 8
我们用表格模拟一下每种情况:

i 的值01234567
栈内数据:[0][1][2][2,3][2,3,4][2,5][6][6,7]

当i=2到i=5时,可以看到里面的变化,不断的将小的出栈,将大的进栈,不断的更新下标的差。

例题2

456. 132 模式
这个题比第一个难一些,但是理解之后也不是很难
题解:

 public boolean find132pattern(int[] nums) {
	//定义单调栈
        Deque<Integer> stack = new ArrayDeque<>();
        int k = Integer.MIN_VALUE;
        for(int i = nums.length - 1;i>=0;i--){
            if(nums[i] < k ) return true;
            while(!stack.isEmpty() && stack.peek() < nums[i]){
                k = stack.pop();
            }
            stack.push(nums[i]);
        }
        return false;

    }

这个题目不在详细讲了,上面的单调栈理解之后这个题解也是可以看懂的。粘一个大佬的题解:
【宫水三叶の相信科学系列】详解为何使用「单调栈」来找最大的 K 是正确的

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

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

相关文章

第四届宁波网安市赛初赛

由于赛后官方不给wp&#xff08;绿盟一向如此&#xff09;&#xff0c;交流群也没有得到其他题解&#xff0c;赛后就根据自己的wp来写了&#xff0c;wp由队友及我共同完成。比赛共解答10题&#xff0c;Web 5道&#xff0c;Misc 2道&#xff0c;Crypto 3道&#xff0c;wp只有一部…

深度学习算法面试常问问题(一)

博主秋招遇到的面试问题以及整理其他面经相关问题&#xff0c;无偿分享~ 项目叙述&#xff1a; 算法需求及应用场景算法的调研和初步方案的制定数据的准备&#xff08;包括数据标注和数据增强&#xff09;算法的介绍&#xff08;包括输入和输出&#xff0c;loss、backbone、训…

做外贸,你不能不懂的外贸流程知识

报关是履行海关进出境手续的必要环节之一&#xff0c;涉及两大类:进出境运输工具、物品和货物。由于性质不同&#xff0c;报关手续也有些不同。今天我就为大家详细介绍一下进出口报关的流程&#xff0c;包括出口货物报关的流程&#xff0c;随报关单提交的运费和商业单据&#x…

Spark中cache、persist、checkpoint三者的比较

原文链接&#xff1a;https://blog.csdn.net/AnameJL/article/details/124362219&#xff0c;再次主要是为了方便查找&#xff0c;把原文章复制一遍 目录 1. 三者的使用 1.1 cache的讲解与使用 1.2 persist的讲解与使用 1.3checkpoint 的讲解与使用 2. 三者的比较 2.1 优…

基于Web的智慧能源可视化管理系统

自工业革命开始&#xff0c;全球能源消耗持续增长&#xff0c;由碳循环体系破坏引发的全球变暖、海平面上升等问题严重影响着人类的可持续发展。得益于数字孪生、物联网、5G、AI识别等技术的不断成熟&#xff0c;以“大数据能源监控、精细化能源管理”为核心的智慧能源解决方案…

【电子学会】2022年12月图形化三级 -- 绘制雷达

绘制雷达 1. 准备工作 &#xff08;1&#xff09;绘制黑色背景&#xff1b; &#xff08;2&#xff09;删除默认角色小猫&#xff0c;添加角色Pencil。 2. 功能实现 &#xff08;1&#xff09;画笔的颜色设为黄色&#xff0c;Pencil的中心点设在笔尖位置&#xff0c;画笔的…

在Java 中 利用Milo通信库,实现OPCUA客户端,并生成证书

程序结构&#xff1a; 配置文件resources&#xff1a; opcua.properties 西门子PLC端口号为4840&#xff0c;kepserver为49320 #opcua服务端配置参数 #opcua.server.endpoint.urlopc.tcp://192.168.2.102:49320 opcua.server.endpoint.urlopc.tcp://192.168.2.11:4840 opcu…

2023年私募股权基金研究报告

第一章 概况 PE是私募&#xff0c;也即私募投资基金&#xff0c;是指以非公开发行方式向合格投资者募集的&#xff0c;投资于股票、股权、债券、期货、期权、基金份额及投资合同约定的其他投资标的&#xff08;如艺术品、红酒等&#xff09;的投资基金&#xff0c;简称私募基金…

【PyTorch学习3】《PyTorch深度学习实践》——反向传播(Back Propagation)

目录一、Tensor1.定义2.Tensor常见形式3.torch.tensor和torch.Tensor4.Tensor.grad二、反向传播一、Tensor 1.定义 张量的定义是一个可用来表示在一些矢量、标量和其他张量之间的线性关系的多线性函数。 在PyTorch上有这样一句话&#xff0c;A torch.Tensor is a multi…

TeeChart for .NET 2023.2.13 Crack

TeeChart NET Pro Edition 是一个基于 Nuget 的图表控件&#xff0c;旨在为您的 NET 应用程序提供即时图表、地图和仪表功能。TeeChart 拥有数十种图表类型、统计函数和开发人员工具&#xff0c;是当今开发人员可用的最全面的图表库之一。易于使用设计时编辑器和直观的编程结构…

蒙特卡洛计算圆周率

使用MC计算圆周率的小例子&#xff0c;使用python的numpy&#xff0c;matplotlib库import numpy as npimport matplotlib.pyplot as pltdef mc_calculate_pi(t):np.random.seed(t)rand_num np.random.rand(t)rand_num2 np.random.rand(t)l1 rand_num-0.5l2 rand_num2-0.5l0…

记录-配置unity多人游戏服务器中的踩坑经历

最近沉迷于gpt这个“魔法海螺”无法自拔&#xff0c;总之这是题外话了&#xff0c;Let.s go 文章目录前言一、IIS的HTTPS站点设置二、VS的远程部署设置三、运行.NET CORE的IIS站点——注意项四、SQL Server使用sa账号不能登录的问题解决五、SVN忽略so文件的提交&#xff0c;导致…

深入浅出带你学习IIS中间件常见漏洞

前言 在渗透过程中我们经常会思考如何去进行渗透&#xff0c;假如给了我们一个有很多中间件的网站我们要如何进行渗透呢&#xff1f;于是本人准备写一些包含常见中间件漏洞攻击的总结&#xff0c;希望可以帮到大家在面临不同渗透环境时会有渗透思路&#xff0c;本篇文章就先给…

开源单点登录MaxKey和JumpServer 堡垒机单点登录集成指南

1. MaxKey介绍 MaxKey社区专注于身份安全管理(IM)、单点登录(SSO)和云身份认证(IDaas)领域&#xff0c;将为客户提供企业级的身份管理和认证&#xff0c;提供全面的4A安全管理&#xff08;指Account&#xff0c;Authentication&#xff0c;Authorization和Audit&#xff09;。…

HCIP中期实验(华为)

题目&#xff1a; 实验要求&#xff1a; 1、该拓扑为公司网络&#xff0c;其中包括公司总部、公司分部以及公司骨干网&#xff0c;不包含运营商公网部分。 2、设备名称均使用拓扑上名称改名&#xff0c;并且区分大小写。 3、整张拓扑均使用私网地址进行配置。 4、整张网络中&am…

javaEE 初阶 — 延迟应答与捎带应答

文章目录1. 延迟应答2. 捎带应答TCP 工作机制&#xff1a;确认应答机制 超时重传机制 连接管理机制 滑动窗口 流量控制与拥塞控制 1. 延迟应答 延时应答 也是提升效率的机制&#xff0c;也是在滑动窗口基础上搞点事情。 滑动窗口的关键是让窗口大小大一点&#xff0c;传输…

骑行是什么?骑行是这十一非物质的东西

很多骑友一直在想&#xff0c;我们骑行是为什么&#xff1f;又没有什么实质性的价值&#xff0c;又不算是劳动&#xff0c;但究竟是什么&#xff1f;让我们坚持不懈的在坚持&#xff0c;在热爱&#xff1f; 1.骑行是一种自由&#xff0c;它可以让你放松心情&#xff0c;放空思绪…

JS中的数据类型判断

JS中的数据类型 基本数据类型 number、string、boolean、null、undefined、symbol 引用数据类型 object、array、function、date、regexp 判断数据类型的方法有 typeof 、instanceof、constructor、toString() typeof用法 从上面可以看出&#xff0c;typeof 对于JS中基本类型…

Promise学习笔记(一)

课程内容 1、Promise基础 2、手写Promise 3、Async和Await 4、应用实战 1、初始Promise 1.1、promise介绍 1.2、回调地狱&#xff08;嵌套金字塔&#xff09; 1.3、promise使用 &#xff08;1&#xff09;then(成功函数&#xff0c;失败函数)&#xff1a;要么使用then传…

滑块连杆模型仿真(三菱ST+博途SCL计算源代码)

由滑块位置逆计算曲柄角度,请参看下面的文章链接。这篇博客主要计算由曲柄转动角度计算滑块位置。 https://blog.csdn.net/m0_46143730/article/details/128943228https://blog.csdn.net/m0_46143730/article/details/128943228简单的看下连杆滑块模型 模型的数学推导过程,大…