当前位置:首页 > 科技  > 软件

数组结构~什么是单调栈

来源: 责编: 时间:2023-08-09 23:02:09 253观看
导读什么是栈要弄明白什么是栈,我们需要先举一个生活中的例子。假如有一个又细又长的圆筒,圆筒一端封闭,另一端开口。往圆筒里放 入乒乓球,先放入的靠近圆筒底部,后放入的靠近圆筒入口。那么,要想取出这些乒乓球,则只能按照和放

什么是栈

要弄明白什么是栈,我们需要先举一个生活中的例子。jcn28资讯网——每日最新资讯28at.com

假如有一个又细又长的圆筒,圆筒一端封闭,另一端开口。往圆筒里放 入乒乓球,先放入的靠近圆筒底部,后放入的靠近圆筒入口。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

那么,要想取出这些乒乓球,则只能按照和放入顺序相反的顺序来取,先取出后放入的,再取出先放入的,而不可能把最里面最先放入的乒乓球优先取出。jcn28资讯网——每日最新资讯28at.com

栈(stack)是一种线性数据结构,它就像一个上图所示的放入乒乓球的 圆筒容器,栈中的元素只能先入后出 (First In Last Out,简称FILO )。最早进入的元素存放的位置叫作栈底 (bottom),最后进入的元素 存放的位置叫作栈顶 (top)。jcn28资讯网——每日最新资讯28at.com

栈这种数据结构既可以用数组来实现,也可以用链表来实现。jcn28资讯网——每日最新资讯28at.com

栈的数组实现如下。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

栈的链表实现如下。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

那么,栈可以进行哪些操作呢?栈的最基本操作是入栈和出栈,下面让我们来看一看。jcn28资讯网——每日最新资讯28at.com

栈的基本操作

入栈

入栈操作(push)就是把新元素放入栈中,只允许从栈顶一侧放入元素,新元素的位置将会成为新的栈顶。jcn28资讯网——每日最新资讯28at.com

这里我们以数组实现为例。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

出栈

出栈操作(pop)就是把元素从栈中弹出,只有栈顶元素才允许出栈,出栈元素的前一个元素将会成为新的栈顶。jcn28资讯网——每日最新资讯28at.com

这里我们以数组实现为例。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

入栈和出栈操作,时间复杂度分别是多少?jcn28资讯网——每日最新资讯28at.com

入栈和出栈只会影响到最后一个元素,不涉及其他元素的整体移动,所以无论是以数组还是以链表实jcn28资讯网——每日最新资讯28at.com

现,入栈、出栈的时间复杂度都是O(1) 。jcn28资讯网——每日最新资讯28at.com

什么是单调栈

单调递增栈 从栈底到栈顶的元素关键字的大小单调递增;jcn28资讯网——每日最新资讯28at.com

单调递减栈 从栈底到栈顶的元素关键字的大小单调递减;jcn28资讯网——每日最新资讯28at.com

适用问题:jcn28资讯网——每日最新资讯28at.com

要知道单调栈的适用于解决什么样的问题,我们首先需要知道单调栈的作用。单调栈分为单调递增栈和单调递减栈,通过使用单调栈我们可以访问到下一个比他大(小)的元素(或者说可以)。jcn28资讯网——每日最新资讯28at.com

也就是说在队列或数组中,我们需要通过比较前后元素的大小关系来解决问题时我们通常使用单调栈。jcn28资讯网——每日最新资讯28at.com


jcn28资讯网——每日最新资讯28at.com

举个栗子

有一个地方要传授武林秘籍,大家要在这一天之前来这里排好队等着学习武林秘籍。来了很多武林高手,但是这个地方的人要根据人来的先后顺序教,先来的学的武功就高深,来的越靠后学的就越差,但是能保证只要来就能学到。假如他们一开始有一个初始的排队顺序和武力水平如下所示,大家可以按照这个初始顺序从前往后学习。jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

问题来了,武力值高的肯定愿意先学习到高深一点的武功啊,那我就找到前面武力值低的人说:“你别学了,我教你一门武功,然后离开,否则就咔嚓了你✂️”,武力值低的那听就答应了也就只能无可奈何的打印了,从后来的那个人那里哪里学了一门武术就离开了,这样武功高的那个就排在了前面。下面我们来从前往后模拟一下过程:jcn28资讯网——每日最新资讯28at.com

(1)首先来的是炮灰甲,炮灰甲一看,OK,栈内没有人就可以先排在第一位jcn28资讯网——每日最新资讯28at.com

(2)然后扫地僧来了,扫地僧教给了炮灰甲一招易筋经,然后扫地僧让炮灰甲离开自己排在第一位。jcn28资讯网——每日最新资讯28at.com

(3)然后杨过过来,看到前面是扫地僧,自己打不过只能老老实实站到队里。jcn28资讯网——每日最新资讯28at.com

(4)后面一直来人(如3)------ 直到张三 对里面站的是 扫地僧 杨过 慕容复 张三 。jcn28资讯网——每日最新资讯28at.com

(5)然后张无忌来了,他首先看到前面是张三,张无忌教给张三一招武当梯云纵,然后让张三离开了,张无忌再往前看到了慕容复教他一招太极拳,然后继续直到遇到扫地僧,OK,自己打不过,老老实实的占到了后面 —现在队里有扫地僧,张无忌 ----杨过,慕容复,张三的师傅为张无忌jcn28资讯网——每日最新资讯28at.com

(6)柯镇恶来了,打不过,站到后面就好了。jcn28资讯网——每日最新资讯28at.com

(7)然后乔峰来了把柯镇恶和张无忌打发走, —现在队里有扫地僧,乔峰。jcn28资讯网——每日最新资讯28at.com

(8)然后李四来了,打不过乔峰,只能站到了最后。jcn28资讯网——每日最新资讯28at.com

(9)第二天扫地僧,乔峰,李四成功学到了武林秘籍jcn28资讯网——每日最新资讯28at.com

现在看他们分别学到武功对应如下图:jcn28资讯网——每日最新资讯28at.com

jcn28资讯网——每日最新资讯28at.com

这样我们就处理完了所有过程。因此单调栈的时间复杂度为O(n),在比较时对出栈的元素有一个处理(例如扫地僧让炮灰甲走的时候教给他自己的武功),另外最后留在站内的元素有一个统一的处理(扫地僧,乔峰,李四成功学到了武林秘籍)。jcn28资讯网——每日最新资讯28at.com

伪代码如下所示:jcn28资讯网——每日最新资讯28at.com

对于第i个到来的人:jcn28资讯网——每日最新资讯28at.com

  • 每当队里面有人并且打不过自己的时候:
  • 让这个人离开并交给他自己的武功
  • 自己入队

LCR 039. 柱状图中最大的矩形

jcn28资讯网——每日最新资讯28at.com

思路:有了单调栈的基本认识,我们可以遍历每根柱子,以当前柱子 i 的高度作为矩形的高,那么矩形的宽度边界即为向左找到第一个高度小于当前柱体 i 的柱体,向右找到第一个高度小于当前柱体 i 的柱体。对于每个柱子我们都如上计算一遍以当前柱子作为高的矩形面积,最终比较出最大的矩形面积即可。jcn28资讯网——每日最新资讯28at.com

单调栈实现:寻找两边距离arr[i]最近且arr[i]小的索引,保持栈顶到栈底单调递减,栈中存放索引值。jcn28资讯网——每日最新资讯28at.com

注意:头0如果不添加,寻找左边元素需要判断栈是否为空;尾0如果不添加,需要重新写一个循环弹出栈内元素。jcn28资讯网——每日最新资讯28at.com

class Solution {    public int largestRectangleArea(int[] heights) {        int n = heights.length;        int [] left = new int[n];        int [] right = new int[n];        Stack<Integer> stack = new Stack<>();        for(int i = 0; i < n; i++){            while (!stack.isEmpty() && heights[i] <= heights[stack.peek()]){                stack.pop();            }            left[i] = (stack.isEmpty() ? -1: stack.peek());            stack.push(i);        }        stack.clear();        for(int i = n-1; i >= 0; i--){            while (!stack.isEmpty() && heights[i] <= heights[stack.peek()]){                stack.pop();            }            right[i] = (stack.isEmpty() ? n : stack.peek());            stack.push(i);        }        int res = 0;        for(int i = 0; i < n; i++){            res = Math.max(res, (right[i] - left[i] - 1) * heights[i]);        }        return res;    }}

42.接雨水

该题目有多种解法,本次只介绍单调栈的方式,对其它算法感兴趣的朋友可以自己去尝试一下~~jcn28资讯网——每日最新资讯28at.com

思路:理解题目注意题目的性质,当后面的柱子高度比前面的低时,是无法接雨水的,当找到一根比前面高的柱子,就可以计算接到的雨水。所以使用单调递减栈:jcn28资讯网——每日最新资讯28at.com

  • 对更低的柱子入栈,更低的柱子以为这后面如果能找到高柱子(可以理解为 代码中的 left ),这里就能接到雨水,所以入栈把它保存起来。
  • 当出现高于栈顶(代码中 top)的柱子时说明可以对前面的柱子结算了
class Solution {    public int trap(int[] height) {        int ans = 0;        Stack<Integer> stack = new Stack<Integer>();        int n = height.length;        for (int i = 0; i < n; ++i) {            while (!stack.isEmpty() && height[i] > height[stack.peek()]) {                int top = stack.pop();                if (stack.isEmpty()) {                    break;                }                int left = stack.peek();                int currWidth = i - left - 1;                int currHeight = Math.min(height[left], height[i]) - height[top];                ans += currWidth * currHeight;            }            stack.push(i);        }        return ans;    }}


jcn28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-5102-0.html数组结构~什么是单调栈

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 如何优雅地处理RabbitMQ中的消息丢失

下一篇: 聊聊如何理解流量分发

标签:
  • 热门焦点
  • 鸿蒙OS 4.0公测机型公布:甚至连nova6都支持

    鸿蒙OS 4.0公测机型公布:甚至连nova6都支持

    华为全新的HarmonyOS 4.0操作系统将于今天下午正式登场,官方在发布会之前也已经正式给出了可升级的机型产品,这意味着这些机型会率先支持升级享用。这次的HarmonyOS 4.0支持
  • K60至尊版刚预热 一加Ace2 Pro正面硬刚

    K60至尊版刚预热 一加Ace2 Pro正面硬刚

    Redmi这边刚如火如荼的宣传了K60 Ultra的各种技术和硬件配置,作为竞品的一加也坐不住了。一加中国区总裁李杰发布了两条微博,表示在自家的一加Ace2上早就已经采用了和PixelWo
  • Redmi Buds 4开箱简评:才199还有降噪 可以无脑入

    Redmi Buds 4开箱简评:才199还有降噪 可以无脑入

    在上个月举办的Redmi Note11T Pro系列新机发布会上,除了两款手机新品之外,Redmi还带来了两款TWS真无线蓝牙耳机产品,Redmi Buds 4和Redmi Buds 4 Pro,此前我们在Redmi Note11T
  • 6月安卓手机好评榜:魅族20 Pro蝉联冠军

    6月安卓手机好评榜:魅族20 Pro蝉联冠军

    性能榜和性价比榜之后,我们来看最后的安卓手机好评榜,数据来源安兔兔评测,收集时间2023年6月1日至6月30日,仅限国内市场。第一名:魅族20 Pro好评率:95%5月份的时候魅族20 Pro就是
  • 十个简单但很有用的Python装饰器

    十个简单但很有用的Python装饰器

    装饰器(Decorators)是Python中一种强大而灵活的功能,用于修改或增强函数或类的行为。装饰器本质上是一个函数,它接受另一个函数或类作为参数,并返回一个新的函数或类。它们通常用
  • 从零到英雄:高并发与性能优化的神奇之旅

    从零到英雄:高并发与性能优化的神奇之旅

    作者 | 波哥审校 | 重楼作为公司的架构师或者程序员,你是否曾经为公司的系统在面对高并发和性能瓶颈时感到手足无措或者焦头烂额呢?笔者在出道那会为此是吃尽了苦头的,不过也得
  • 梁柱接棒两年,腾讯音乐闯出新路子

    梁柱接棒两年,腾讯音乐闯出新路子

    文丨田静 出品丨牛刀财经(niudaocaijing)7月5日,企鹅FM发布官方公告称由于业务调整,将于9月6日正式停止运营,这意味着腾讯音乐长音频业务走向消亡。腾讯在长音频领域还在摸索。为
  • 三星折叠屏手机去年销售近1000万台 今年目标定为1500万

    三星折叠屏手机去年销售近1000万台 今年目标定为1500万

    7月29日消息,三星率先发力可折叠手机市场,在全球市场已经取得了非常亮眼的成绩,接下来会进一步巩固和扩大这一优势。三星在推出Galaxy Z Flip5和Galax
  • 滴滴违法违规被罚80.26亿 共存在16项违法事实

    滴滴违法违规被罚80.26亿 共存在16项违法事实

    滴滴违法违规被罚80.26亿 存在16项违法事实开始于2121年7月,历经一年时间,网络安全审查办公室对“滴滴出行”网络安全审查终于有了一个暂时的结束。据“网信
Top