42. 接雨水(leetcode)

news/2024/9/23 0:50:20/文章来源:https://www.cnblogs.com/lxl-233/p/18426176

https://leetcode.cn/problems/trapping-rain-water/description/
大厂经典题,接雨水
暴力双指针->预处理优化->单调栈

暴力:

class Solution {public int trap(int[] height) {// 暴力解法:// 枚举每一个柱子为底,双指针寻找左右最高的柱子,这样就找到了一个凹槽// 找到凹槽后累加答案int res=0;for(int i=0;i<height.length;i++){int maxL=i,maxR=i;for(int l=i-1;l>=0;l--)if(height[l]>=height[maxL])maxL=l;for(int r=i+1;r<height.length;r++)if(height[r]>=height[maxR])maxR=r;// 获得左右最高柱子后,即明确了以i为底的列的雨水高度int h = Math.min(height[maxL],height[maxR])-height[i];// int h = Math.min(lHeight, rHeight) - height[i];if(h>0) res+=h; // 左右没有比i高的,h会小于0}return res;}
}

预处理优化:

class Solution {public int trap(int[] height) {// 预处理解法:int res=0;// 存储每个柱子左右最高(包括自己)的柱子高度,类似于前缀和优化(前缀最大值与后缀最大值),但是公式上类似于dpint[] maxL=new int[height.length];int[] maxR=new int[height.length];// 预处理每个柱子左边的最高高度maxL[0]=height[0]; // 左边没有比自己搞的了,就用自己高度for(int i=1;i<height.length;i++){maxL[i]=Math.max(height[i],maxL[i-1]);}maxR[height.length-1]=height[height.length-1]; // 右边没有比自己高的了for(int i=height.length-2;i>=0;i--){maxR[i]=Math.max(height[i],maxR[i+1]);}for(int i=0;i<height.length;i++){// 获得左右最高柱子后,即明确了以i为底的列的雨水高度int h = Math.min(maxL[i],maxR[i])-height[i];res+=h; // h>=0,不用判断}return res;}
}

单调栈

class Solution {public int trap(int[] height) {// 单调栈解法:// 枚举每一个柱子为底部,左右第一个高于底部的柱子,围城的凹槽,累计答案(横向求解)// 利用当前枚举的右边第一个高的柱子right,与栈top作为底,利用单调递增// 使用栈后面的元素作为left来计算凹槽面积// 如此一个凹槽一个凹槽的计算即可int res=0;Deque<Integer> st = new ArrayDeque<>();for(int i=0;i<height.length;i++){// 当前枚举的柱子比过去遍历的柱子要高,则是当前柱子右边第一个高的柱子while(!st.isEmpty() && height[i] >= height[st.peek()]){int mid = height[st.pop()];if(st.isEmpty()) break;int left=st.peek();int h=Math.min(height[i],height[st.peek()])-mid;res+= h * (i-left-1);}st.push(i);// 当前柱子不是右边第一个高的柱子}return res;}
}

 

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

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Java反序列化利用链篇 | CC1链的第二种方式-LazyMap版调用链【本系列文章的分析重点】

CC1链的第二种方式-LazyMap版调用链 目录LazyMap构造payloadCC1的调用链参考链接LazyMap 在之前的CC1链中分析,其实是其中一种方式(国内版本),还有另外一种方式,也是ysoserial中的CC1链的方式(国外版本)。 区别在于调用transform的类是不同的。 在寻找transform调用的时…

瑞云科技AIGC云平台:重塑电商设计流程!

在快节奏的电商市场中,商品更新换代的速度越来越快,而电商设计团队传统的设计流程和工作模式却难以满足当前行业对快速响应、高效发展和降低成本的实际需求.对此,瑞云科技针对电商设计行业的痛点,提供了全新的AIGC创作云平台.从2022年ChatGPT的发布到,AI正以惊人的速度席卷全球…

学习高校课程-软件工程-敏捷开发(ch5)

WHAT IS AGILITY 什么是敏捷性 An agile team is a nimble team able to appropriately respond to changes. Change is what software development is very much about. Changes in the software being built, changes to the team members, changes because of new technolog…

从零开始一个git操作实例,图文并茂

徒弟不懂git怎么用, 于是写了篇文章, 把本地git操作从头写了一遍, 自己去看吧!0、基本概念 •Git是一个免费、开源的、分布式版本控制系统 •它使用一个特殊的叫做仓库的数据库来记录文件的变化 •仓库中的每个文件都有一个完整的版本历史记录 1)安装 sudo apt-update sud…

Java反序列化利用链篇 | JdbcRowSetImpl利用链分析

JdbcRowSetImpl利用链 前言 首先说明一下:利用链都有自己的使用场景,要根据场景进行选择不同的利用链。 JdbcRowSetImpl利用链用于fastjson反序列化漏洞中。 为什么? 因为fastjson会在反序列化类时自动调用set开头的方法(不一定是setter方法),而JdbcRowSetImpl中存在一个…

Java反序列化调用链分析系列 | URLDNS链

URLDNS链 URLDNS链是java通过反序列化发起dns请求的利用链。一般用于测试反序列化漏洞。 该链比较简单,利用链也比较短。 其中入口类为 HashMap,执行类为URLStreamHandler的hashCode()方法。 整个调用链如下: HashMap.readObject() HashMap.putVal() HashMap.hash()URL.hash…

控制请求并发数量:p-limit 源码解读

p-limit 是一个控制请求并发数量的库,他的整体代码不多,思路挺好的,很有学习价值; 举例 当我们同时发起多个请求时,一般是这样做的 Promise.all([requestFn1,requestFn2,requestFn3 ]).then(res =>{})或者 requestFn1() requestFn2() requestFn3()而使用 p-limit 限制并…

程序员职业发展之路思考:工程师的等级阶梯

德雷福斯模型:新手到专家 德雷福斯模型(Dreyfus model)是在 1980 年,Dreyfus 兄弟共同提出的技能习得模型。 它是一个技能习得的阶梯模型,也可以用来考察行业技术能手的分级。该模型由上而下分成:专家、精通者、胜任者、高级新手、新手五个等级,越到上面人数占比越少。新…

2024 人工智能学习内容

第六组思维导图:图形的认识

04. 流程控制

一、流程控制流程控制就是用来控制程序运行中各语句执行顺序的语句。基本的流程结构为:顺序结构,分支结构(或称选择结构),循环结构。顺序结构:程序自上到下执行,中间没有任何判断和跳转; 分支结构:根据条件,选择性的执行某段代码,有 if……else 和 switch……case 两…

CentOS 7 虚拟机连接网络

CentOS 7 虚拟机连接网络 检查网络 ping www.baidu.com切换 root 用户 su查看网卡名 ip addr激活网卡 vim /etc/sysconfig/network-scripts/ifcfg-ens33重启网络 service network restart

execve

目录glibc glibc execve() 执行由 pathname 指定的程序。这会导致当前正在被调用进程运行的程序被一个新程序替换,且该新程序会重新初始化栈、堆,以及(已初始化和未初始化的)数据段。