Leetcoder Day43| 单调栈2

503.下一个更大元素II

给定一个循环数组(最后一个元素的下一个元素是数组的第一个元素),输出每个元素的下一个更大元素。数字 x 的下一个更大的元素是按数组遍历顺序,这个数字之后的第一个比它更大的数,这意味着你应该循环地搜索它的下一个更大的数。如果不存在,则输出 -1。

示例 1:

  • 输入: [1,2,1]
  • 输出: [2,-1,2]
  • 解释: 第一个 1 的下一个更大的数是 2;数字 2 找不到下一个更大的数;第二个 1 的下一个最大的数需要循环搜索,结果也是 2。

提示:

  • 1 <= nums.length <= 10^4
  • -10^9 <= nums[i] <= 10^9

本题和每日温度思路基本一致,多出一步对于循环数组的处理。遇到循环数组,第一个想法就是取数组长度的模,即i%len

class Solution {
    public int[] nextGreaterElements(int[] nums) {
        Stack<Integer> stack = new Stack<>();
        int len=nums.length;
        int[] res = new int[len];
        Arrays.fill(res, -1);
        for(int i=0;i<len*2;i++){
            while(!stack.isEmpty() && nums[stack.peek()]<nums[i%len]){
                res[stack.peek()]=nums[i%len];
                System.out.print(i+" ");
                System.out.println(res[stack.peek()]);
                stack.pop();
            }
            stack.push(i%len);
        }
        return res;
    }
}

42. 接雨水

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

示例 1:

  • 输入: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 个单位的雨水(蓝色部分表示雨水)。

示例 2:

  • 输入:height = [4,2,0,3,2,5]
  • 输出:9

本题需要计算能接到多少雨水,也就是计算合理的柱子数目及其容量。合理的柱子需要满足下面的条件:

  • 同时拥有左右两侧
  • 柱子能接雨水的高度取决于矮柱子的高度

那么问题的关键在于,如何判断柱子的左右边界?如何计算容量?

首先更推荐按照列来计算容量,这样子宽度一定为1,把每一列满足条件的高度计算出来即可。

对于确定左右边界,需要分别从左和从右找到最高的列。

第一个柱子和最后一个柱子无法盛雨水

对于列1:

左边没有比当前高的柱子,所以无法盛雨水

对于列2:

  • 左边最高的柱子为列1,高度为1
  • 右边最高的柱子为列7,高度为3
  • 列2高度为0
  • 所以列2能容纳的雨水容量为:min(列1高度,列7高度)-列2高度=1-0=1

对于列3:

左边没有比它更高的柱子,所以无法盛雨水

对于列4:

  • 左边最高的柱子为列3,高度为2
  • 右边最高的柱子为列7,高度为3
  • 列4高度为1
  • 所以列4能容纳雨水容量为:min(列3高度,列7高度)-列4高度=2-1=1

以此类推。但是这个思路需要消耗O(n^2)的时间复杂度,测试用例不通过

class Solution {
    public int trap(int[] height) {
        if(height==null) return 0;
        int sum=0;
        for(int i=1;i<height.length-1;i++){
            int lH=height[i];
            int rH=height[i];
            for(int r=i+1;r<height.length;r++){ //找右边最大的边
                rH=height[r]>rH?height[r]:rH;
            }
            for(int l=i-1;l>=0;i--){// 找左边最大的边
                lH=height[l]>lH?height[l]:lH; 
            }
            int h=Math.min(lH,rH)-height[i];
            if(h>0) sum+=h;
        }
        return sum;
    }
}

可以看到本题本质依然是寻找任一个元素的右边或者左边第一个比自己大或者小的元素的位置,接雨水这道题目,我们正需要寻找一个元素,右边最大元素以及左边最大元素,来计算雨水面积,所以还是可以考虑用到单调栈。

将本题看作求每根柱子可以容纳雨水的体积,高度为下图所示:

宽度如下图:

先将a,b,c压入栈中,此时遇到了一个比栈顶e的高度更大的c,

则e柱能容纳的水高度为min(b,c)-e,宽度为c的下标-b的下标;

b柱能容纳的雨水高度为min(a,c)-b,宽度为 c的下标-a的下标;

最后能容纳的雨水容量为高*宽

class Solution {
    public int trap(int[] height) {
        if(height==null) return 0;
        int sum=0;
        Stack<Integer> stack= new Stack<>();
        int len=height.length;
        stack.push(0);
        for(int i=1;i<len;i++){
            while(!stack.isEmpty() && height[stack.peek()]<height[i]){
                int top=height[stack.peek()];  //先记录栈顶元素的高度
                stack.pop(); //将栈顶元素弹出
                if(!stack.isEmpty()){//说明有左边
                    int h=Math.min(height[stack.peek()], height[i])-top;  //计算高度
                    int w=i-stack.peek()-1;
                    sum+=h*w;
                }
            }
            stack.push(i);
        }
        return sum;
    }
}

84.柱状图中最大的矩形

给定 n 个非负整数,用来表示柱状图中各个柱子的高度。每个柱子彼此相邻,且宽度为1。求在该柱状图中,能够勾勒出来的矩形的最大面积。

本题看起来和接雨水很类似,都是求面积,但是接雨水是找每个柱子左右两边第一个大于该柱子高度的柱子,分别求宽和高然后相乘,而本题是找左右两侧最近的高度小于当前高度的柱子,所以本题应该是从栈顶到栈尾单调递减栈

class Solution {
    public int largestRectangleArea(int[] heights) {
        int max=0;
        Stack<Integer> stack = new Stack<>();
        int len=heights.length;
        int[] newHeight = new int[len+ 2]; //定义一个新数组,加入头和尾
        System.arraycopy(heights, 0, newHeight, 1, len); 
        for(int i=0;i<newHeight.length;i++){
             while (!stack.isEmpty() && newHeight[i] < newHeight[stack.peek()]) {//需要弹
                int h=newHeight[stack.peek()];
                stack.pop();
                int w=i-stack.peek()-1;
                max=max>h*w?max:h*w;

            }
            stack.push(i);
        }
        return max;
    }
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024最新Guitar Pro 8.1中文版永久许可证激活

Guitar Pro是一款非常受欢迎的音乐制作软件&#xff0c;它可以帮助用户创建和编辑各种音乐曲谱。从其诞生以来就送专门为了编写吉他谱而研发迭代的。 尽管这款产品可能已经成为全球最受欢迎的吉他打谱软件&#xff0c;在编写吉他六线谱和乐队总谱中始终处于行业领先地位&#x…

大话设计模式之原型模式

原型模式&#xff08;Prototype Pattern&#xff09;是一种创建型设计模式&#xff0c;它用于创建对象的复制&#xff0c;同时又能保持对象的封装。原型模式通过复制现有对象的方式来创建新的对象&#xff0c;而无需知道具体创建过程的细节。 在原型模式中&#xff0c;通常会有…

Excel·VBA数组分组问题

看到一个帖子《excel吧-数据分组问题》&#xff0c;对一组数据分成4组&#xff0c;使每组的和值相近 目录 代码思路1&#xff0c;分组形式、可分组数代码1代码2代码2举例 2&#xff0c;数组所有分组形式举例 这个问题可以转化为2步&#xff1a;第1步&#xff0c;获取一组数据…

【大数据运维】minio 常见shell操作

文章目录 1. 安装2. 入门操作3. 命令帮助 1. 安装 下载 https://dl.min.io/client/mc/release/linux-amd64/ 赋权与使用 cp mc /usr/bin && chmod x /usr/bin/mc ./mc --help 2. 入门操作 # 添加minio到mc mc config host add minio_alias_name endpoint_adress …

SpringBoot动态数据源实现

一、背景 一个应用难免需要连接多个数据库&#xff0c;像我们系统起码连接了5个以上数据库&#xff0c;AWS RDS主库&#xff0c;ECS自搭MySQL从库&#xff0c;工厂系统三个SQLServer数据库&#xff0c;在线网站MySQL数据库&#xff0c;记得很早以前是用SessionFactory配置&…

Java中有哪些容器(集合类)?

Java中的集合类主要由Collection和Map这两个接口派生而出&#xff0c;其中Collection接口又派生出三个子接 口&#xff0c;分别是Set、List、Queue。所有的Java集合类&#xff0c;都是Set、List、Queue、Map这四个接口的实现 类&#xff0c;这四个接口将集合分成了四大类&#…

C语言--编译和链接

1.翻译环境 计算机能够执行二进制指令&#xff0c;我们的电脑不会直接执行C语言代码&#xff0c;编译器把代码转换成二进制的指令&#xff1b; 我们在VS上面写下printf("hello world");这行代码的时候&#xff0c;经过翻译环境&#xff0c;生成可执行的exe文件&…

WebGIS概述

1.地图组成 底图(Map): 所有信息的载体 图层(Layer):将不同地理信息分类形成的一个集合 要素(Feature):表示不同的地物 几何(Geometry): 信息的数据模型和抽象 2.地图容器Container 即在准备阶段所创建的指定了id的div对象&#xff0c;这个div将作为承载所有图层、点标记、矢量…

分布式部署LNMP+WordPress

需要四台虚拟机&#xff0c;实际上&#xff0c;我们只需要操作三台 一个数据库&#xff0c;一个nginx&#xff0c;一个php&#xff0c;还需要准备一个软件包wordpress-4.7.3-zh_C 首先配置nginx的服务环境 [rootnginx ~]# vi /usr/local/nginx/conf/nginx.conf 修改文件中的loc…

2024软件设计师备考讲义——(4)

知识产权和标准化 一、知识产权 1.特性 无体性专有性地域性时间性 2.保护期限 公民作品 署名权、修改权、保护作品完整权【没有限制】发表权、使用权、获得报酬权【终身及死亡后第50年12月31日】单位作品 发表权、使用权、获得报酬权【首次发表后到第50年12月31日】公民软件…

【Linux】nmcli命令详解(文末送书)

目录 一、概述 二、常用参数使用 2.1 nmcli networking 1.显示NM是否接管网络 2.查看网络连接状态 3.开/关网络连接 2.2 general ​编辑 1.显示系统网络状态 2.显示主机名 3.更改主机名 2.3 nmcli connection ​编辑1.显示所有网络连接 2.显示某个网卡的详细信息…

修改mysql数据库默认字符集

查看系统版本&#xff0c;数据库版本 前提你必须已经安装好了mysql。 参考&#xff1a;https://blog.csdn.net/qq_50247813/article/details/137137915 查看mysql的默认字符集 show variables like %char%; 查看数据库默认字符集 SELECT collation_database; 查看数据库默认…

携手伙伴 共赢智改数转 锐捷网络企业行业合作伙伴大会圆满举行

3月22日,锐捷网络2024全国企业行业合作伙伴大会在福州成功举行。大会以“追光而遇,沐光同行”为主题,吸引了来自全国各地的合作伙伴齐聚“有福之州”,共同探讨企业数智化转型新机遇和新方向。 会上,锐捷网络渠道客户系统部总经理王刚为此次合作伙伴大会开幕致辞。王刚对所有到场…

13 Games101 - 笔记 - 光线追踪(Whitted-Style光线追踪原理详解及实现细节)

13 光线追踪&#xff08;Whitted-Style光线追踪原理详解及实现细节) 引入光线追踪的原因 光栅化的缺点&#xff1a;不能很好的处理全局光照。&#xff08;因为Blinn-Phong这种局部模型无法处理全局效果&#xff01;&#xff09; 光栅化&#xff1a;快 real-time 质量低光线追…

亚马逊、Shine新品如何快速引爆流量?自养号测评实用技巧助你成功

在当今电子商务的浪潮中&#xff0c;亚马逊凭借其卓越的运营模式和庞大的用户基础&#xff0c;已然成为全球在线零售领域的佼佼者。然而&#xff0c;面对平台上数以亿计的商品和激烈的竞争环境&#xff0c;新品要想快速吸引流量并脱颖而出&#xff0c;并非易事。本文旨在深入探…

Flink-CDC 无法增量抽取SQLServer数据

1.问题 因部署在WindowsServer服务器SQLServer发生过期后重启&#xff0c;Flink-CDC同步进行作业重启&#xff0c;启动后无报错信息&#xff0c;数据正常抽取。但是观察几天后发现当天数据计算指标无法展示 2.定位 因为没用进行任何修改&#xff0c;故初步判断不是因Flink-C…

怎么评价小米汽车SU7?

编辑搜图 请点击输入图片描述&#xff08;最多18字&#xff09; 小米汽车SU7&#xff1a;电动智能驾驶的新篇章 随着全球汽车产业的深度变革&#xff0c;新能源汽车、智能驾驶等概念逐渐深入人心。在这场汽车产业的革新中&#xff0c;小米汽车SU7无疑是一个引人注目的焦点。这…

尝试 Sora AI 从文本生成视频

Sora Ai 是一种先进的 AI 模型&#xff0c;能够通过文本制作长达一分钟的视频&#xff0c;包括错综复杂的细节场景、复杂的摄像机运动以及一系列表现出生动情感的角色。此外&#xff0c;它可以从单个静止图像生成视频&#xff0c;或者通过添加新内容来增强现有素材。 Sora Ai …

002-基于Pytorch的手写汉字数字分类

本节将介绍一种 2.1 准备 2.1.1 数据集 &#xff08;1&#xff09;MNIST 只要学习过深度学习相关理论的人&#xff0c;都一定听说过名字叫做LeNet-5模型&#xff0c;它是深度学习三巨头只有Yann Lecun在1998年提出的一个CNN模型&#xff08;很多人认为这是第一个具有实际应用…

雷军把小爱同学喊崩了:小米SU7发布会触发全国小米音箱

站长之家(ChinaZ.com) 3月29日 消息:雷军在昨晚的小米SU7 发布会上意外地让全国的小爱同学陷入了一片混乱。 原来&#xff0c;小米SU7 搭载了一款先进的AI大模型&#xff0c;与小爱同学语音助手完美结合&#xff0c;为用户带来了前所未有的智驾体验。雷军在展示这一功能时&…