Leetcode 42.接雨水

给定 n 个非负整数表示每个宽度为 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

提示:

n == height.length
1 <= n <= 2 * 104
0 <= height[i] <= 105
在这里插入图片描述
单调栈

class Solution {
public:int trap(vector<int>& height) {stack<int> stk;int res = 0;for(int i = 0; i < height.size(); i ++ ) {int last = 0;while(stk.size() && height[stk.top()] <= height[i]) {res += (height[stk.top()] - last) * (i - stk.top() - 1);last = height[stk.top()];stk.pop();}if(stk.size()) res += (height[i] - last) * (i - stk.top() - 1);stk.push(i);}return res;}
};

双指针

class Solution {
public:int trap(vector<int>& height) {int res = 0;int l = 0, r = height.size() - 1;int lmax = 0, rmax = 0;while(l < r) {lmax = max(lmax, height[l]);rmax = max(rmax, height[r]);if(height[l] < height[r]) {res += lmax - height[l];l ++;} else {res += rmax - height[r];r --;}}return res;}
};

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

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

相关文章

多线程(19)活锁和线程饥饿

活锁&#xff08;Livelock&#xff09;和线程饥饿&#xff08;Thread Starvation&#xff09;是并发编程领域中两个至关重要且常见的问题。理解这两个概念&#xff0c;以及它们如何影响程序的执行和系统的性能&#xff0c;对于开发能够有效并行处理任务的应用程序至关重要。 1…

发表SCI论文对作者学位职位有要求吗?

SCI论文是被SCI(Scientific Citation Index&#xff0c;《科学引文索引》)收录的期刊所刊登的论文。能够在SCI上成功发表论文是证明作者的一定的能力被国际研究界所认可&#xff0c;国内的很多科研人员因此对其也是非常向往的。 那么发表SCI论文对作者学位职位有要求吗? 通常…

基于单片机智能输液器监控系统的设计

**单片机设计介绍&#xff0c;基于单片机智能输液器监控系统的设计 文章目录 一 概要二、功能设计设计思路 三、 软件设计原理图 五、 程序六、 文章目录 一 概要 基于单片机智能输液器监控系统的设计旨在实现对输液过程的实时监测和控制&#xff0c;以提高输液的安全性和疗效…

香港服务器与SEO的关系(香港服务器对SEO影响大吗?)

香港服务器与 SEO 的关系是一个备受关注的话题&#xff0c;不少站长在选择了香港服务器后&#xff0c;便会疑问&#xff1a;香港服务器对SEO的影响是否显著?那么&#xff0c;在这里就跟大家聊聊两者的关系以及影响大小。 其实&#xff0c;不少站长对 SEO 的这种担忧和想法是片…

发生播放错误,即将重试 jellyfin

上周在家里的小主机上部署了jellyfin&#xff0c;真香&#xff0c;手机安卓端使用无问题&#xff0c;于是今天准备在电视上安装一个 首先是直接安装的手机版客户端&#xff0c;操作卡顿&#xff0c;而且很多操作没法实现&#xff0c;于是去下了一个tv版本 安装上后发现&#…

R语言数据分析基础(一)

在R中&#xff0c;读取和操作Excel文件最常用的readxl包&#xff0c;可以读取Excel文件&#xff0c;writexl包可以写入Excel文件。以下是常见的操作&#xff1a; 安装和加载包 首先&#xff0c;需要安装和加载readxl和writexl包。 install.packages("readxl") ins…

InternLM2-lesson1

书生浦语大模型全链路开源体系 课程视频&#xff1a;https://www.bilibili.com/video/BV1Vx421X72D/ 开源历程 全面开源&#xff0c;免费商用&#xff01;&#xff01;&#xff01; internlm2模型体系 internlm2根据参数量可以分为7B和20B两个大的版本&#xff0c;每个大的…

Kubernetes篇(二)— 集群环境搭建

目录 前言一、 环境规划集群类型安装方式主机规划 二、环境搭建主机安装环境初始化安装docker安装kubernetes组件准备集群镜像集群初始化安装网络插件 三、 服务部署 前言 本章节主要介绍如何搭建kubernetes的集群环境 一、 环境规划 集群类型 kubernetes集群大体上分为两类…

qt窗口的应用与pyinstaller打包APP操作

3月29日 qt打包APP操作 1 先在windows shell 中下载打包软件Pylnstaller pip install pyinstaller2 先进入py项目所在的位置&#xff0c;再执行以下代码(我用的qt版本是PySide6可以根据自己的情况修改) pyinstaller s02.py --noconsole --hidden-import PySide6.QtXml3 因为…

软件设计不是CRUD(16):低耦合模块设计理论——行为抽象与设计模式(下)

(接上文《软件设计不是CRUD(15):低耦合模块设计理论——行为抽象与设计模式(中)》) 3.2.4、之前的业务逻辑需要关注后续逻辑的执行成败,并调整自身执行的情况 这个场景在之前场景的基础上增加了新的控制要求,具体来说就是之前已经完成的控制逻辑执行,需要在后续控制…

以太网/USB 数据采集卡 24位16通道 labview 256K同步采样

XM7016以太网SUB数据采集卡 XM7016是一款以太网/USB高速数据采集卡&#xff0c;具有16通道真差分输入&#xff0c;24位分辨率&#xff0c;单通道最高采样率256ksps. 16通道同步共计4.096Msps、精密前置增益放大、集成IEPE/ICP硬件支持的特点。本产品采用了多个高精度24位ADC单元…

leetcode-链表算法题

leetcode-链表算法题 237.删除链表中的节点 题目地址 有一个单链表的 head&#xff0c;我们想删除它其中的一个节点 node。 给你一个需要删除的节点 node 。你将 无法访问 第一个节点 head。 链表的所有值都是 唯一的&#xff0c;并且保证给定的节点 node 不是链表中的最后一个…

如何使用 WebView 将 React Native 嵌入到原生应用中

创建 React Native Web Bundle&#xff1a; 首先&#xff0c;需要使用 React Native CLI 或 Expo CLI 构建 React Native 的 Web bundle。你可以使用以下命令来构建 Web bundle&#xff1a; npx react-native bundle --platform web --entry-file index.js --bundle-output ./…

有趣且重要的JS知识合集(21)浏览器内置对象讲解之Dom篇

1、Dom 1.1、概念 Document Object Model&#xff08;文档对象模型&#xff09;, 整个WEB页面, 所有的Dom元素都在Document整个文档里。DOM就是把整个文档页面当做一个对象进行操作, document 下 包含了 根据 html 创建 的 Dom 对象, 这个DOM对象, 以树形结构展示, 即DOM树 …

20240322-2-Catboost面试题

Catboost面试题 1. 简单介绍Catboost&#xff1f; CatBoost是一种以对称决策树 为基学习器的GBDT框架&#xff0c;主要为例合理地处理类别型特征&#xff0c;CatBoost是由Categorical和Boosting组成。CatBoost还解决了梯度偏差以及预测偏移的问题&#xff0c;从而减少过拟合的…

C 传递指针给函数

C 语言允许您传递指针给函数&#xff0c;只需要简单地声明函数参数为指针类型即可。 下面的实例中&#xff0c;我们传递一个无符号的 long 型指针给函数&#xff0c;并在函数内改变这个值&#xff1a; #include <stdio.h> #include <time.h>void getSeconds(unsi…

12.填充

12.填充 - 蓝桥云课 (lanqiao.cn) 问题描述 有一个长度为n的01串&#xff0c;其中有一些位置标记为 ?&#xff0c;这些位置上可以任意填充0或者1&#xff0c;请问如何填充这些位置使得这个01串中出现互不重叠的00和11子串最多&#xff0c;输出子串个数 输入格式 输入一行包含一…

element plus的el-image图片发布到nginx不显示

问题&#xff1a; <el-image alt""src"/img/month-b.png" class"card-icon"style"width: 89px;height: 89px;right: -7px;top: -5px;"/> 部署到nginx二级路由访问地址是&#xff1a; http://192.168.1.207/divided/# 这时候使用…

EasyExcel: 高效处理Excel的现代Java库

引言 在现代数据处理中&#xff0c;Excel表格无疑是一种不可或缺的工具。它不仅用于数据的存储和整理&#xff0c;更是在各个领域中广泛应用的数据分析和展示工具。然而&#xff0c;对于Java开发者而言&#xff0c;在处理Excel文件时常常会遇到一些棘手的问题。 传统的Java操…

使用node爬取视频网站里《龙珠》m3u8视频

1. 找到视频播放网站 百度一下 龙珠视频播放 精挑细选一个可以播放的网站。 如&#xff1a;我在网上随便找了一个播放网站&#xff0c;可以直接在线播放 https://www.xxx.com/play/39999-1-7.html 这里不具体写视频地址了&#xff0c;大家可以自行搜索 2.分析网页DOM结…