LeetCode.42. 接雨水

题目

题目链接

分析

读完本题以及结合题目给出的图我们可以很直观的看到,这道题目是让我们求形成凹槽的面积。

我们可以针对每一个数字形成凹槽的面积进行计算,然后相加数组每一个数字形成凹槽的面积即可。

那么问题来了,怎么知道一个数字是否可以形成凹槽,以及计算形成凹槽的面积。

要想形成凹槽,就必须知道左右两边的最大数,如下图中,1 的左边最大值为2,右边最大值为3,那么针对这个1形成的凹槽面积就是 :min(左边最大值,右边最大值) - height[i]利用上面的规则,我们将会得到一个 preArray 数组 和 sufArray数组,preArray 数组这个数组记录每一个数字的左边的最大值,sufArray数组这个数组记录每一个数字的右边的最大值。
下图我展示了 preArray 和 sufArray 数组,以及每一个元素可以形成凹槽的面积:
在这里插入图片描述

代码

class Solution {public int trap(int[] height) {int n = height.length;int[] preArr = new int[n];preArr[0] = height[0];int[] sufArr = new int[n];sufArr[n-1] = height[n-1];for(int i = 1;i < n;i ++) {preArr[i] = Math.max(preArr[i-1],height[i]);}for(int i = n - 2;i >= 0;i --) {sufArr[i] = Math.max(sufArr[i+1],height[i]);}int res = 0;for(int i = 0;i < n;i ++) {res += Math.min(preArr[i],sufArr[i]) - height[i];}return res;}
}

在这里插入图片描述

拓展

这道题还可以利用双指针的方法来解答。

定义两个指针 left = 0,right = height.length -1
定义一个前缀最大值 pre_max 和 后缀最大值 suf_max

  • 当前缀最大值 < 后缀最大值 时,那么左边木桶的能形成凹槽的面积就是 前缀最大值 - 当前left下标对应的值;然后 left++
  • 当前缀最大值 > 后缀最大值 时,那么右边木桶的能形成凹槽的面积就是 后缀最大值 - 当前right下标对应的值;然后 right–
  • 当前缀最大值 = 后缀最大值 时,更新left还是right都可以。
class Solution {public int trap(int[] height) {int n = height.length;int res = 0;int pre_max = 0;int suf_max = 0;int left = 0;int right = n - 1;while(left < right) {pre_max = Math.max(pre_max,height[left]);suf_max = Math.max(suf_max,height[right]);if(pre_max < suf_max) {res += (pre_max - height[left++]);}else {res += (suf_max - height[right--]);}}return res;}
}

在这里插入图片描述

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

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

相关文章

500行Python代码构建的AI搜索工具!

一个500行Python代码构建的AI搜索工具&#xff0c;而且还会开源&#xff0c;试了一下麻雀虽小该有的都有。 后端是Mixtral-8x7b 模型&#xff0c;托管在 LeptonAI 上&#xff0c;输出速度能达到每秒大约200个 token&#xff0c;用的搜索引擎是 Bing 的搜索 API。 作者还写了一…

Spring: alibaba代码规范校验工具checkstyle

文章目录 一、idea配置checkstyle插件二、激活CheckStyle三、配置自动格式化功能 一、idea配置checkstyle插件 下载 Intellij IDEA Checkstyle 插件&#xff1a;File -> setting -> plugin通过关键字CheckStyle-IDEA搜索并安装。 安裝完成后重启idea 二、激活CheckSty…

海康实时监控预览视频流接入web

我们采取的方案是后端获取视频流返回给前端&#xff0c;然后前端播放 海康开放平台海康威视合作生态致力打造一个能力开放体系、两个生态圈&#xff0c;Hikvision AI Cloud开放平台是能力开放体系的核心内容。它是海康威视基于多年在视频及物联网核心技术积累之上&#xff0c;…

Transformer and Pretrain Language Models3-6

Pretrain Language Models预训练语言模型 content&#xff1a; language modeling&#xff08;语言模型知识&#xff09; pre-trained langue models(PLMs&#xff09;&#xff08;预训练的模型整体的一个分类&#xff09; fine-tuning approaches GPT and BERT&#xff08;…

[C++]priority_queue——优先级队列(含模拟实现)

一、priority_queue是什么 priority_queue 是容器适配器&#xff0c;它提供常数时间的&#xff08;默认&#xff09;最大元素查找&#xff0c;对数代价的插入与释出。 可用用户 提供的 Compare 更改顺序&#xff0c;例如&#xff0c;用 std::greater<T> 将导致最小元素作…

什么是图形组态软件?可视化组态工具的特点

组态软件的定义 组态软件主要作为SCADA系统及其他控制系统的上位机人机界面的开发平台&#xff0c;为用户提供快速地构建工业自动化系统数据采集和实时监控功能服务。它使用灵活的组态方式&#xff0c;提供快速构建工业自动控制系统监控功能的通用层次的软件工具。 组态软件的…

Go、容器以及Linux调度器

在容器中运行Go应用程序时&#xff0c;需要设置合理的GOMAXPROCS&#xff0c;从而避免调度中因为资源不足而造成STW。原文: Go, Containers, and the Linux Scheduler Go开发的应用程序通常部署在容器中。在容器中运行时&#xff0c;重要的一点是要设置CPU限制以确保容器不会耗…

jnekins使用docker部署springboot项目

创建Dockerfile FROM openjdk:21 VOLUME /tmp ADD springboot3-0.0.1-SNAPSHOT.jar app.jar EXPOSE 8888 ENTRYPOINT ["java","-jar","/app.jar","--spring.cloud.nacos.server-addr192.168.8.11:8848"] 新建一个【自由风格】项目 选…

Mac网线上网绿联扩展坞连接网线直接上网-无脑操作

声明&#xff1a;博主使用的绿联扩展坞 以下为绿联扩展坞Mac网线使用方法 1.首先需要下载电脑对应版本的驱动 直接点击即可下载 2. 下载好以后 解压 点进去 对应版本 博主直接使用最新的12-14 3. 安装包好了以后 会提示重启电脑 此时拔掉扩展坞 再重启动 拔掉扩展坞 再重启…

CodeGPT

GitCode - 开发者的代码家园 gitcode.com/ inscode.csdn.net/liujiaping/java_1706242128563/edit?openFileMain.java&editTypelite marketplace.visualstudio.com/items?itemNameCSDN.csdn-codegpt&spm1018.2226.3001.9836&extra%5Butm_source%5Dvip_chatgpt_c…

Android发展历程

安卓基于Linux内核&#xff0c;Linux内核相当于房屋的地基 开源不等于免费&#xff0c;不能商用 安卓一般每半年小更新&#xff0c;一年大更新 对应API相当于别名 现在安卓安全性越来越高&#xff0c;性能越来越快&#xff0c;越更新版本&#xff0c;说明安卓越完善 下载网址 …

盘古信息IMS OS 数垒制造操作系统+ 产品及生态部正式营运

启新址吉祥如意&#xff0c;登高楼再谱新篇。2024年1月22日&#xff0c;广东盘古信息科技股份有限公司新办公楼层正式投入使用并举行了揭牌仪式&#xff0c;以崭新的面貌、奋进的姿态开启全新篇章。 盘古信息总部位于东莞市南信产业园&#xff0c;现根据公司战略发展需求、赋能…