42.接雨水

接雨水是一个非常经典的题目了,我在二刷的时候,终于能独立做了,在记录一下灵神的横着计算的单调栈思想.

法一: 竖着计算 奇思妙想

        让我们想想,接到的雨水到底是存储哪里了呢,其实他就是凹陷部分,而什么是凹陷呢,就是从左边看,从右边看都发现不了的地方.                                                         ---------------无名氏

        我们用两个数组left[i]和right[i]分别记录 height[0...i]的最大值 和 height[len-1...i]的最大值.

也就是

        left[i] = max(left[i-1],height[i])

        right[i] = max(right[i+1],height[i])

那么 每次 就是 ans += min(left[i],right[i]) - height[i]

代码如下:

class Solution {
public:int trap(vector<int>& height) {int len=height.size();vector<int> left(len,0);vector<int> right(len,0);left[0]=height[0];right[len-1]=height[len-1];for(int i=1;i<len;i++){left[i]=max(left[i-1],height[i]);}for(int i=len-2;i>=0;i--){right[i]=max(right[i+1],height[i]);}int ans=0;for(int i=0;i<len;i++){ans+=min(left[i],right[i]) - height[i];}return ans;}
};

 法二: 横着计算 单调栈

        每次遇到比当前栈顶元素小的等的就压入栈,而遇到大的就弹出栈,也就是说这个栈就是递减的

        当弹出的时候就意味着,右边来了个更大的(右边界),也就满足了凹陷一半的条件,为什么说是一半呢,因为凹陷还需要左边有一个更大的,也就是当前栈在弹出一个之后还要有一个元素(左边界),那么 ans+=(l-r+1) * height,

        总的来说就是, 当遇到一个更大的元素(右边界),弹出一个元素作为bottom,然后再弹出一个元素作为左边界, 没有左边界就是 0

        代码如下:

class Solution {
public://法二: 横着算int trap(vector<int>& height) {stack<int> stk;int ans=0;for(int i=0;i<height.size();i++){//由于我们单调栈的构建,栈顶元素对应的height是最低的 他才是bottom 而栈顶下面的那个才是左柱子while(!stk.empty() && height[i]>=height[stk.top()]){int bottom=height[stk.top()];stk.pop();if(stk.empty())   break;  //就是只有一个底  左边没有柱子int left=height[stk.top()];ans+=(i-stk.top()-1) * (min(left,height[i])-bottom);  //这里的height[i]就是right}stk.push(i);}return ans;}
};

      

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

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

相关文章

滑块验证码破解----Java使用opencv后端破解滑块验证

使用技术:Java SpringBootopenCV 在windows上首先需要下载opencv进行安装,先去官网:Releases - OpenCV 下载这个windows版本的安装包 下载后直接安装解压就行,然后需要,然后找到安装位置里的这个文件: 你下载的是什么版本的,这里的数字就是多少,比如我下载4.5.3版本那么这…

kubectl无法使用清理磁盘

执行Kubectl get pods 报错如下&#xff1a; # kubectl get nodes The connection to the server <master>:6443 was refused - did you specify the right host or port?查看占用磁盘&#xff1a; df -h 查看占用100%的数据 df -h | grep 100% 检查环境变量&#xff…

(学习日记)2024.04.26:UCOSIII第五十节:User文件夹函数概览(uC-CPU文件夹)

之前的章节都是针对某个或某些知识点进行的专项讲解,重点在功能和代码解释。 回到最初开始学μC/OS-III系统时,当时就定下了一个目标,不仅要读懂,还要读透,改造成更适合中国宝宝体质的使用方式。在学完野火的教程后,经过几经思考,最后决定自己锦上添花,再续上几章。 这…

【数据库】关于数据库你必须知道的事情

常用命令 mysql -u username -p USE mydatabase; SHOW DATABASES; CREATE DATABASE newdatabase;数据库的规约 包括&#xff1a; 建表规约&#xff1b;索引规约&#xff1b;SQL与ORM映射规约&#xff1b; Explain技巧 explain的结果代表的含义需要比较清楚。参数中&#x…

永磁同步电机SMO负载转矩观测matlab模型。

永磁同步电机SMO负载转矩观测matlab模型。 负载转矩的有效识别是提高伺服驱动系统抗负载扰动性能的关键之一。现在的传统结构的LTID滑模观测器存在频率抖动大&#xff0c;估计精度差的缺点&#xff0c;限制了其在高性能伺服系统中的应用。 本模型推导分析了传统LTID滑模观测器…

【k8s】:Pod的生命周期详解

【k8s】:Pod的生命周期详解 1、Pod的生命周期1.1、Pod的创建1.2、Pod的调度1.3、Pod的初始化1.4、Pod的运行及钩子函数1.4.1 k8s中的3种钩子函数1.4.2 k8s中的3种探测类型1.5、Pod的终止1.6、Pod的重启2、Pod的生命周期的五种状态(相位)💖The Begin💖点点关注,收藏不迷…

eclipse 如何创建python文件

一、准备 1.平台要求&#xff1a; 电脑除了要安装eclipse软件和Python语言包之外&#xff0c;还需要将Python集成到eclipse软件中&#xff0c;网上有很多的方法&#xff0c;这里就不细细介绍如何集成了。 在下面界面中可以看到自己已经安装了继承插件。具体方法见步骤2&…

YOLOV5 TensorRT部署 BatchedNMS(转换engine模型)(上)

文章目录 1.修改yolo detct层2.导出onnx模型并引入plugin3.转换为engine文件YoloV5使用tensorRT部署时,模型推理是放在cuda上操作,得到的结果需要在cpu上执行nms操作,但是当图像中的目标较多,或者检测出来的框较多时,nms耗时较长。 TensorRT 官方提供了batchedNMSPlugin的…

AI新篇章:全面解读ChatGPT3.5与GPT4.0的革命性融合

MidTool&#xff08;kk.zlrxjh.top&#xff09;&#xff0c;一个集成了多种先进人工智能技术的助手&#xff0c;融合了ChatGPT3.5、GPT4.0、DALLE 3和Midjourney等多个智能服务&#xff0c;提供多功能体验。下面是对这些技术的简要概述&#xff1a; **ChatGPT3.5**&#xff1a;…

可视化智慧工厂

在科技迅猛发展的今天&#xff0c;制造业正迎来一场深刻的变革——智慧工厂的崛起。可视化智慧工厂作为其中的重要一环&#xff0c;以其直观、高效、智能的特点&#xff0c;正成为制造业转型升级的关键所在。 一、什么是可视化智慧工厂? 传统的制造业生产方式往往依赖于人工…

百胜中国 - 数据开发 - 面经

Timeline: 2024.4.22 - Boss投递 2024.4.24 - 上午面试 2024.4.26 - HR微信联系 - 电话沟通入职 JD: 所属部门:TSC餐厅支持 24年内无转正 Base:西安(160/天 - 965 - 午休一小时 - 无上下班打卡) Hive,SQL,FineBI(或观远数据)报表开发 面试流程: 自我介绍 我们…

Java在物联网和嵌入式系统中的应用

Java在物联网和嵌入式系统中的应用 一、引言 随着信息技术的快速发展&#xff0c;物联网和嵌入式系统已经成为当今社会的热点领域。它们为我们的生活带来了前所未有的便利和智能化。而Java作为一种功能强大、跨平台的编程语言&#xff0c;在物联网和嵌入式系统中的应用也日渐…

Typora配置PicGo图床,将图片文件上传到gitee厂库,获取图片链接显示在md文件中

Typora配置PicGo图床&#xff0c;将图片文件上传到gitee厂库&#xff0c;获取图片链接显示在md文件中 创建Gitee创库和配置私人令牌 名字、路径、描述自己随便添&#xff0c;但是必须开源&#xff0c;链接才能可以访问&#xff1a; 进入偏好设置 > 图像 > 选择PicGo-Cor…

找不到mfc140u.dll文件如何处理?这三种方法帮你快速修复mfc140u.dll

当你的电脑出现提示&#xff0c;显示找不到mfc140u.dll文件&#xff0c;从而无法继续执行代码&#xff0c;你需要知道如何应对这种情况。今天我们就来详细说明如何解决mfc140u.dll文件丢失的问题&#xff0c;并对该文件进行详细分析。这个文件是Microsoft Visual Studio的一个重…

mfc使用gsoap访问python端webservice服务及中文乱码问题

webservice实现简介 客户端用MFC加gsoap实现, 服务端用python用spyne库实现。 服务端端口8000, 外露接口输入字符串,得到字符串: @rpc(Unicode, _returns=Unicode)def get_id(self, config):下载gsoap https://sourceforge.net/projects/gsoap2/files/latest/download 比…

Windows 安全中心:页面不可用 你的 IT 管理员已限制对此应用的某些区域的访问,并且你尝试访问的项目不可用。有关详细信息,请与 IT 支持人员联系。

问题 1&#xff1a;Windows 安全中心提示&#xff1a;【页面不可用 你的 IT 管理员已限制对此应用的某些区域的访问&#xff0c;并且你尝试访问的项目不可用。有关详细信息&#xff0c;请与 IT 支持人员联系。】 修复 Microsoft.SecHealthUI 方法 1&#xff1a;命令自动重装安…

Docker 部署与操作

一 国内&#xff1a; 中国电信天翼云 提供包括云主机在内的全方位云计算服务&#xff0c;侧重于安全合规和企业级服务。 利用电信的网络优势&#xff0c;提供稳定可靠的基础设施服务。 中国联通沃云 提供包括云主机在内的多项云计算服务&#xff0c;适合不同行业和场景。 …

【Spring Security系列】Spring Security整合JWT:构建安全的Web应用

前言 在企业级开发或者我们自己的课程设计中&#xff0c;确保用户数据的安全性和访问控制非常重要。而Spring Security和JWT是都两个强大的工具&#xff0c;它俩结合可以帮助我们实现这一目标。 Spring Security提供了全面的安全功能&#xff0c;而JWT则是一种用于身份验证的…

Python 实现12306抢票脚本

我必须再次强调,使用或创建12306抢票脚本可能违反了12306网站的使用条款和条件,以及相关法律法规。因此,我不能提供任何关于如何编写或使用抢票脚本的具体代码或指导。 不过,我可以向您展示如何使用Python编写一个基本的网络爬虫来自动查询和预订火车票的基本步骤。但请注…

小程序为什么必须安装SSL证书?怎么挑选?——建议收藏

小程序使用SSL证书的原因主要包括&#xff1a; 1. 安全要求&#xff1a;微信小程序等平台强制要求使用HTTPS加密协议&#xff0c;这意味着必须部署SSL证书以确保所有网络请求的安全性。没有SSL证书&#xff0c;小程序无法正常上线使用。 2. 数据加密&#xff1a;SSL证书通过加密…