【算法】单调栈

2023-09-20 09:47:20

💝💝💝欢迎来到我的博客,很高兴能够在这里和您见面!希望您在这里可以感受到一份轻松愉快的氛围,不仅可以获得有趣的内容和知识,也可以畅所欲言、分享您的想法和见解。
img

  • 推荐:kuan 的首页,持续学习,不断总结,共同进步,活到老学到老
  • 导航
    • 檀越剑指大厂系列:全面总结 java 核心技术点,如集合,jvm,并发编程 redis,kafka,Spring,微服务,Netty 等
    • 常用开发工具系列:罗列常用的开发工具,如 IDEA,Mac,Alfred,electerm,Git,typora,apifox 等
    • 数据库系列:详细总结了常用数据库 mysql 技术点,以及工作中遇到的 mysql 问题等
    • 懒人运维系列:总结好用的命令,解放双手不香吗?能用一个命令完成绝不用两个操作
    • 数据结构与算法系列:总结数据结构和算法,不同类型针对性训练,提升编程思维,剑指大厂

非常期待和您一起在这个小小的网络世界里共同探索、学习和成长。💝💝💝 ✨✨ 欢迎订阅本专栏 ✨✨

一.介绍

1.什么是单调栈?

单调栈(Monotonic Stack)是一种数据结构,通常用于解决一些与查找数组中下一个较大或较小元素相关的问题。单调栈的主要特点是它维护一个单调递增或单调递减的栈,根据具体问题的要求选择递增或递减。

单调栈的基本思想是,当元素入栈时,它会与栈内的元素进行比较,将不满足单调性要求的元素弹出,以确保栈内的元素保持单调性。这样做的好处是在 O(n)的时间复杂度内,可以高效地找到每个元素的下一个较大或较小的元素,而无需遍历整个数组。

2.单调栈的应用场景

常见的应用场景包括:

  1. 下一个较大元素:给定一个数组,对于每个元素,找到数组中右边第一个比它大的元素。
  2. 下一个较小元素:给定一个数组,对于每个元素,找到数组中右边第一个比它小的元素。
  3. 柱状图中的最大矩形面积:给定一个表示柱状图的数组,找到可以形成的最大矩形的面积。
  4. 滑动窗口最大值:给定一个数组和一个固定大小的窗口,找到每个窗口中的最大值。

单调栈通常使用栈数据结构实现,通过在入栈和出栈操作时维护单调性,从而解决上述问题。在具体应用时,需要根据问题的性质来选择单调递增或单调递减的栈。

单调栈是一种非常有用的数据结构,用于解决与查找下一个较大或较小元素相关的问题,它可以帮助在更高效的时间复杂度内解决这些问题。

二.练习

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。
image-20230918112149304

输入:height = [0,1,0,2,1,0,1,3,2,1,2,1]
输出:6
解释:上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。
public class E02Trap42_03 {
    /**
     * 构造对象
     */
    static class Data {
        int index;//索引位置
        int height;//当前高度

        public Data(int index, int height) {
            this.index = index;
            this.height = height;
        }
    }

    public int trap(int[] height) {
        int res = 0;
        LinkedList<Data> stack = new LinkedList<>();
        //遍历数组
        for (int i = 0; i < height.length; i++) {
            //右节点,当前节点
            final int curr = height[i];
            final Data right = new Data(i, curr);
            while (!stack.isEmpty() && stack.peek().height < curr) {
                final Data pop = stack.pop();
                final Data left = stack.peek();
                //计算面积
                if (left != null) {
                    //宽度
                    int width = right.index - left.index - 1;
                    int high = Math.min(right.height, left.height) - pop.height;
                    res += width * high;
                }
            }
            stack.push(right);
        }
        return res;
    }
}

觉得有用的话点个赞 👍🏻 呗。
❤️❤️❤️本人水平有限,如有纰漏,欢迎各位大佬评论批评指正!😄😄😄

💘💘💘如果觉得这篇文对你有帮助的话,也请给个点赞、收藏下吧,非常感谢!👍 👍 👍

🔥🔥🔥Stay Hungry Stay Foolish 道阻且长,行则将至,让我们一起加油吧!🌙🌙🌙

img

更多推荐

Java版本spring cloud + spring boot企业电子招投标系统源代码

项目说明随着公司的快速发展,企业人员和经营规模不断壮大,公司对内部招采管理的提升提出了更高的要求。在企业里建立一个公平、公开、公正的采购环境,最大限度控制采购成本至关重要。符合国家电子招投标法律法规及相关规范,以及审计监督要求;通过电子化平台提高招投标工作的公开性和透明性;通过电子化招投标,使得招标采购的质量更高、速度

Week2:包含 min 函数的栈

1️⃣题目描述定义栈的数据结构,请在该类型中实现一个能够得到栈的最小元素的min函数在该栈中,调用min、push及pop的时间复杂度都是O(1)。示例:MinStackminStack=newMinStack();minStack.push(-2);minStack.push(0);minStack.push(-3)

代码随想录算法训练营Day45 | 动态规划(7/17) LeetCode 70. 爬楼梯 (进阶) 322. 零钱兑换 279.完全平方数

开始第七天的练习!第一题70.ClimbingStairsYouareclimbingastaircase.Ittakesnstepstoreachthetop.Eachtimeyoucaneitherclimb1or2steps.Inhowmanydistinctwayscanyouclimbtothetop?在刚进

ScrollView如何裁剪粒子特效

1)ScrollView如何裁剪粒子特效2)Unreal在移动设备中无法使用Stat命令获取到GPUThread的耗时3)Unity中如何看到相机视野范围内的剔除结果这是第354篇UWA技术知识分享的推送,精选了UWA社区的热门话题,涵盖了UWA问答、社区帖子等技术知识点,助力大家更全面地掌握和学习。Rendering

Zero-Shot 使用简单两层网络不用训练就能进行图像恢复

文章今天要分享的文章是CVPR2023比较有意思的一篇《Zero-ShotNoise2Noise:EfficientImageDenoisingwithoutanyData》,通过简单的两层网络,并且不需要数据训练直接进行图像恢复代码https://colab.research.google.com/drive/1i8

Si314 低功耗 14 通道电容触摸传感器,软硬件兼容替代GTX314L

Si314是一款具有自动灵敏度校准功能的14通道电容传感器,其工作电压范围为1.8~5.5V。Si314设置休眠模式来节省功耗,此时,功耗电流为10uA@3.3V。Si314各个感应通道可实现独立使能、校准、灵敏度调节,可以确保可靠性,且具有自适应滤波功能,以应对各种噪音和环境变化。I2C串行接口可以读写内部寄存器,检

OpenStack创建云主机并连接CRT

文章目录OpenStackT版创建云主机并连接CRT命令行操作(1)创建镜像(2)创建实例(3)创建网络创建内网创建外网(4)创建安全组(5)创建路由(6)创建云主机(7)绑定浮动IP(8)登录云主机(9)CRT连接图形化操作(1)创建镜像(2)创建实例(3)创建网络创建内网创建外网(4)创建安全组(5)创建路由(6)

MTR 网络连通性测试工具 基础入门 整理

MTRMTR的全称是mytraceroute,是一个集合了ping与traceroute功能的网络诊断工具,广泛应用于链路测试。相对于traceroute只会做一次链路跟踪测试,mtr会对链路上的相关节点做持续探测并给出相应的统计信息。因此,mtr能避免节点波动对测试结果的影响,所以其测试结果更正确,建议优先使用。安装

Vue进阶(幺陆玖)信创适配改造

文章目录一、前言二、方案实施2.1存在的问题2.2方案优化2.3User-Agent详解三、拓展阅读一、前言随着外部监管对国产化的要求越来越高,所在产品团队信创专项改造工作开始实施,需求如下:信创平台控件只能使用在信创终端使用,不能应用在Windows上,存量系统运行过程中需要能够识别业务人员当前使用的终端操作系统,若

【算法练习Day3】 移除链表元素&&设计链表&&反转链表

​​📝个人主页:@Sherry的成长之路🏠学习社区:Sherry的成长之路(个人社区)📖专栏链接:练题🎯长路漫漫浩浩,万事皆有期待文章目录移除链表元素其他问题设计链表其他问题反转链表其他问题总结:移除链表元素203.移除链表元素-力扣(LeetCode)链表问题大多都可以用虚拟头结点的方法,使链表的插入和删除操

实施主品牌进化战略(三):建立产品竞争与进化体系

产品早晚都会抵达成熟期,所以建立一个有效的产品竞争与进化体系,才能保障产品更新迭代与时俱进在跨周期中实现增长和主品牌进化。同时这也是工业制造、汽车制造、软件开发、食品饮料、人工智能等行业强者穿越周期的战略共性。3M:以超级技术打造产品竞争与进化体系3M公司,诞生于1902年,以胶粘技术起家,后发展出光学、医疗、研磨以及

热文推荐