力扣面试经典算法150题:接雨水

接雨水

今天的题目是力扣面试经典算法150题中的困难难度数组题目:分发糖果。

题目链接:https://leetcode.cn/problems/trapping-rain-water/description/?envType=study-plan-v2&envId=top-interview-150

题目描述

给定 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 个单位的雨水(蓝色部分表示雨水)。
      在这里插入图片描述

题目分析

题目内容不多,主要还是看示例中的图片来进行分析。

首先题目会给定一个非负整数数组,数组的每个元素对应到坐标上的一个柱状图。如上图。

题目的要求是,我们需要计算出这个数组中可以容下多少单位的水。 注意Y坐标轴不参于接水。

对于题目的要求,比较考验空间想象能力以及空间计算能力。

解题思路

困难题目名不虚传啊,昨天的开胃菜一对比确实不难。

这个题目要解答主要有两个点需要确定。

  1. 我们首先要界定两个位置,确保这个两个位置可以接住水,比如示例中下标1到下标3中间可以接水,下标3到下标7又开始接水,下标8到下标10又可以接水。
  2. 确定边界位置以后,我们要计算能装多少水。注意,这里我们确定能装的水的数量,不能等确定两个边界后再算,这样比较难算,我们应该在每次向下获取下标值判定是否到边界时就应该把移动这个下标所能装的水的数量计算好。

思考到这里,其实方法已经出现了。没错,就是双指针法。

双指针法也是老演员了,数组题目可以说出现很多次了。

那么本题使用双指针法解答如下:

  1. 初始化指针:
    left 和 right 分别指向数组的起始位置和末尾位置。
    leftMax 和 rightMax 分别记录左侧和右侧的最大高度。
    water 用于累计总的雨水量。
  2. 移动指针:
    如果 height[left] < height[right],则移动左指针。
    否则,移动右指针。
  3. 更新最大高度:
    如果当前高度大于等于已知的最大高度,则更新最大高度。
    否则,当前位置可以接住的雨水量为最大高度减去当前位置的高度。
  4. 累计雨水量:
    将每次计算的雨水量累加到 water 中。

实际算法代码

以下是双指针法的代码实现:

public class Solution {public static void main(String[] args) {Solution solution = new Solution();int[] height = {0, 1, 0, 2, 1, 0, 1, 3, 2, 1, 2, 1};System.out.println(solution.trap(height)); // 输出 6}public int trap(int[] height) {if (height == null || height.length <= 2) {return 0;}int left = 0;int right = height.length - 1;int leftMax = 0;int rightMax = 0;int water = 0;while (left < right) {if (height[left] < height[right]) {// 如果左指针的高度小于右指针的高度if (height[left] >= leftMax) {// 更新左侧最大高度leftMax = height[left];} else {// 左侧当前位置可以接住的雨水量water += leftMax - height[left];}left++; // 移动左指针} else {// 如果右指针的高度小于等于左指针的高度if (height[right] >= rightMax) {// 更新右侧最大高度rightMax = height[right];} else {// 右侧当前位置可以接住的雨水量water += rightMax - height[right];}right--; // 移动右指针}}return water;}
}

结果

运行代码,输出结果符合预期:

在这里插入图片描述

提交到力扣,也通过测试:

在这里插入图片描述

总结

双指针法,用多很多次了,这里不再多废话讲。后面写一篇数组刷题总结。

还剩一题,加油!!!

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

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

相关文章

常见的管理系统简称

1. ERP (Enterprise Resource Planning) - 企业资源计划 定义: ERP是一种集成了企业各个业务模块&#xff08;如财务、人力资源、生产、供应链、销售等&#xff09;的管理系统&#xff0c;旨在通过统一的平台来优化企业资源的配置和使用。 功能和特点: 集成性: ERP系统将企业…

python库pdf转word

要在 Python 中将 PDF 文件转换为 Word 文档&#xff08;.doc 或 .docx 格式&#xff09;&#xff0c;您可以使用几个不同的库来实现这一目标。这里介绍几种常用的库及其使用方法&#xff1a; 1. 使用 pdf2docx pdf2docx 是一个流行的 Python 库&#xff0c;用于将 PDF 文件转换…

【Rust】006-Rust 枚举与`match`、`if let`、`let else`

【Rust】006-Rust 枚举与match、if let、let else 文章目录 【Rust】006-Rust 枚举与match、if let、let else一、简介二、使用场景三、基本使用1、定义枚举2、使用枚举 四、功能详解1、带数据的枚举2、使用match进行模式匹配3、使用if let简化特定变体的处理4、使用let else处…

0904作业+思维导图

一、作业 &#xff08;将昨天的作业修改为标准模板类的&#xff09; 1、代码 #include <iostream> #include <stack> using namespace std; //队列模板类 template<typename T> class Queue { private:int max; //队列最大容量int num; //队列内…

pikachu文件包含漏洞靶场通关攻略

本地文件包含 首先&#xff0c;在靶场根目录下创建一个php文件&#xff0c;内容是phpinfo(); 其次&#xff0c;上传一个任意球星图片&#xff0c;会跳转到带有filename参数的php文件下 然后&#xff0c;将filename的参数改为可以访问到我们创建的php文件的地址 ../../../../…

【计算机】1GB与1Gb与MB的关系

背景 看到个规格书列的芯片规格参数有错误&#xff0c;给对方指出来了下&#xff0c;并做了下科普。做下记录。 关系 1 Gb&#xff08;Gigabit&#xff09;和1 GB&#xff08;Gigabyte&#xff09;之间的区别主要在于“b”和“B”的含义。通常&#xff1a; 1 Gb (Gigabit) 中…

TCP协议多进程多线程并发服务器

TCP多进程多线程并发服务器 1.多进程并发服务器 #include <myhead.h>#define SERPORT 6666 #define SERIP "192.168.0.136" #define BLACKLOG 10void hande(int a) {if(aSIGCHLD){while(waitpid(-1,NULL,WNOHANG)!-1);//回收僵尸进程} }int main(int argc, c…

【Grafana】Prometheus结合Grafana打造智能监控可视化平台

✨✨ 欢迎大家来到景天科技苑✨✨ &#x1f388;&#x1f388; 养成好习惯&#xff0c;先赞后看哦~&#x1f388;&#x1f388; &#x1f3c6; 作者简介&#xff1a;景天科技苑 &#x1f3c6;《头衔》&#xff1a;大厂架构师&#xff0c;华为云开发者社区专家博主&#xff0c;…

Oracle 客户端 PL/SQL Developer 15.0.4 安装与使用

目录 官网下载与安装 切换中文与注册 连接Oracle数据库 tnsnames.ora 文件使用 Oracle 客户端 PL/SQL Developer 12.0.7 安装、数据导出、Oracle 执行/解释计划、for update。 官网下载与安装 1、官网&#xff1a;https://www.allroundautomations.com/products/pl-sql-d…

Redis的配置和启动+Redis Insight连接

一、安装 Redis的安装&#xff1a;从镜像站下载&#xff1a;索引 redis-local (huaweicloud.com)&#xff0c;然后将其传到Linux虚拟机中进行解压&#xff0c;解压之后需要下载gcc&#xff0c;因为Redis底层是用c写的&#xff0c;所以要编译一下生成redis文件&#xff0c;然后…

vite项目配置本地开发使用https访问

在Vite项目中启用HTTPS以安全地使用navigator.mediaDevices.getUserMedia() 引言 在现代Web开发中&#xff0c;保护用户隐私和数据安全是至关重要的。特别是在涉及到媒体捕获功能&#xff0c;如使用用户的摄像头或麦克风时&#xff0c;Web应用需要遵循严格的安全准则。naviga…

反向迭代器:reverse_iterator的实现

目录 前言 特点 注意事项 实现 构造函数 功能函数 在list与vector中的使用 vector list 前言 反向迭代器是一种在序列容器的末尾开始&#xff0c;并向前移动至序列开始处的迭代器。在C中&#xff0c;反向迭代器由标准库中的容器类提供&#xff0c;比如vector、list、d…

Ansible剧本编写指南:从简单任务到复杂自动化的实现

Ansible剧本编写指南&#xff1a;从简单任务到复杂自动化的实现 Ansible 是一个流行的开源自动化工具&#xff0c;被广泛用于配置管理、应用部署、任务自动化以及 IT 基础设施的编排。它的核心是简单且易于学习的 YAML 格式&#xff0c;使用户能够编写可重用、可维护的剧本&am…

Qt 字符串的编码方式,以及反斜杠加3个数字是什么编码\344\275\240,如何生成

Qt 字符串的编码方式 问题 总所周知&#xff0c;Qt的ui文件在编译时&#xff0c;会自动生成一个ui_xxxxx.h的头文件&#xff0c;打开一看&#xff0c;其实就是将摆放的控件new出来以及布局的代码。 只要用Qt提供的uic.exe工具&#xff0c;自己也可以将ui文件输出为代码文件…

rust feature 简介

Rust 的 feature 是一种机制&#xff0c;用于在编译时选择性地启用或禁用代码的某些部分。通过 feature&#xff0c;你可以在 Cargo.toml 中定义哪些功能需要启用&#xff0c;并在代码中通过条件编译来控制代码的编译与否。下面是 feature 机制的详解&#xff1a; 1. 基本概念…

设计模式 18 备忘录模式

设计模式 18 创建型模式&#xff08;5&#xff09;&#xff1a;工厂方法模式、抽象工厂模式、单例模式、建造者模式、原型模式结构型模式&#xff08;7&#xff09;&#xff1a;适配器模式、桥接模式、组合模式、装饰者模式、外观模式、享元模式、代理模式行为型模式&#xff…

c# 笔记 winform添加右键菜单,获取文件大小 ,多条件排序OrderBy、ThenBy,list<double>截取前5个

Winform右键菜单‌ 要在C# Winform应用程序中添加右键菜单&#xff0c;‌你可以按照以下步骤操作&#xff1a;‌ 1.‌创建菜单项‌ 在Form的构造函数或加载事件中&#xff0c;‌创建ContextMenuStrip控件的实例&#xff0c;‌并为其添加菜单项。‌ 2.‌绑定到控件‌ 将Con…

tcp 流量控制

TCP流量控制是TCP/IP协议中用于控制发送方和接收方之间数据传输速率的一种机制&#xff0c;以防止网络拥塞和确保网络资源的有效利用。流量控制主要通过调整TCP窗口大小来实现&#xff0c;确保发送方不会发送超出接收方处理能力的数据量。以下是TCP流量控制的关键概念和工作原理…

c++ websocket简单讲解

只做简单讲解。 一.定义和原理 WebSocket 是从 HTML5 开始⽀持的⼀种⽹⻚端和服务端保持⻓连接的消息推送机制&#xff0c;传统的 web 程序都是属于 "⼀问⼀答" 的形式&#xff0c;即客⼾端给服务器发送了⼀个 HTTP 请求&#xff0c;服务器给客⼾端返回⼀个 HTTP 响…

Java 入门指南:Java 并发编程 —— 并发容器 PriorityBlockingQueue

BlockingQueue BlockingQueue 是Java并发包&#xff08;java.util.concurrent&#xff09;中提供的一个阻塞队列接口&#xff0c;它继承自 Queue 接口。 BlockingQueue 中的元素采用 FIFO 的原则&#xff0c;支持多线程环境并发访问&#xff0c;提供了阻塞读取和写入的操作&a…