什么时候用单调栈呢?
通常是一维数组,要寻找任一个元素的右边第一个比自己大或者左边第一个比自己小的元素的位置,此时我们就要想到可以用单调栈了。
时间复杂度为$O(n)$。
单调栈的本质
空间换时间,因为在遍历的过程中需要用一个栈来记录右边第一个比当前元素大的元素
优点是只需要遍历一次。
在使用单调栈的时候首先要明确如下几点:
单调栈里存放的元素是什么?
单调栈里只需要存放元素的下标i就可以了,如果需要使用对应的元素,直接T[i]就可以获取。
单调栈里元素是递增
注意一下顺序为 从栈头到栈底的顺序,因为单纯的说从左到右或者从前到后,不说栈头朝哪个方向的话,大家一定会越看越懵。
这里我们要使用递增循序(再强调一下是指从栈头到栈底的顺序),因为只有递增的时候,加入一个元素i,才知道栈顶元素在数组中右面第一个比栈顶元素大的元素是i。
文字描述理解起来有点费劲,接下来我画了一系列的图,来讲解单调栈的工作过程。
使用单调栈主要有三个判断条件。
当前遍历的元素T[i]小于栈顶元素T[st.top()]的情况
当前遍历的元素T[i]等于栈顶元素T[st.top()]的情况
当前遍历的元素T[i]大于栈顶元素T[st.top()]的情况
LeetCode42. 接雨水接雨水
原创
©著作权归作者所有:来自51CTO博客作者张无忌的猪的原创作品,请联系作者获取转载授权,否则将追究法律责任
提问和评论都可以,用心的回复会被更多人看到
评论
发布评论
相关文章
-
小谈设计模式(23)—桥接模式
对Java设计模式中的桥接模式进行了详细解读
桥接模式 插入图片 设计模式 -
python接twitch,wx,b站的简单应用
简单介绍最近写的机器人
Bot 微信 Twitch b站 -
LeetCode42 接雨水
leecode:接雨水,考察动态规划、双指针知识,难度等级:困难。
算法 数据结构 Math 数组 空间复杂度 -
【LeetCode】42. 接雨水
42. 接雨水(二维)一、题目描述给定 n 个非负整数】
算法 数据结构 leetcode python 动态规划 -
LeetCode42_接雨水
1. 题目给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少
python gevent 多任务 数组 sed -
【LeetCode】接雨水
字节跳动公司面试高频考题:接雨水。本题圈出单调栈解法中最重要的一个环节:去重复的工作是如何巧妙完成的?
leetcode 算法 入栈 单调栈 数组 -
springclouu 打包引入字体
起因:项目开发完成 需要打包部署了 发现自己不会打包 那么开始网上学习打包?那么怎么来打包那?我们以前没有采用springboot 时候我们都是直接将项目打成war包形式 然后放到tomcat webapp下面 开始打包:我对原理现在也不是很理解 我给出的是自己对打成包 并运
springclouu 打包引入字体 java 开发工具 spring apache