【LeetCode最详尽解答】42-接雨水 Trapping-Rain-Water

欢迎收藏Star我的Machine Learning Blog:https://github.com/purepisces/Wenqing-Machine_Learning_Blog。如果收藏star, 有问题可以随时与我交流, 谢谢大家!

链接:

  • 42-接雨水

直觉

通过可视化图形来解决这个问题会更容易理解和解决。

给定输入: 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 个单位的雨水被困住。

Trapping-Rain-Water

最初,我尝试同时移动左指针和右指针,但在到达右半部分 [3,2,1,2,1] 时遇到了问题。这时,左指针指向值 3,而右指针指向数组的末尾。右边界值小于左边界值,无法形成雨水陷阱。

这是错误的解决方案:

class Solution(object):def trap(self, height):""":type height: List[int]:rtype: int"""l = 0 r = 1area = 0while l < r and r < len(height)-1 :while height[r] < height[l] and r < len(height)-1 :r+=1for i in range(l+1,r):area+=height[l] -height[i]l = rr = l +1return area

然后,我观看了 NeetCode 的视频,他将左右指针分别初始化为数组的起始和结束位置。此外,还使用了两个变量 leftmaxrightmax。每次移动较小的值并将当前面积累加到最终结果中。如果 rightmax 较小,它会向左移动,因为无法从左指针陷阱雨水,并加上当前面积值 rightmax - height[r]。相反,如果 leftmax 较小,则加上面积值 leftmax - height[l] 并向右移动检查下一个值。

方法

  • 初始化两个指针 leftright,分别位于数组的起始和结束位置。
  • 初始化 leftmaxrightmax 为起始和结束位置的值。
  • 移动较小的值并更新最大值,将面积值累加到最终结果中。

复杂度

  • 时间复杂度:
    O ( n ) O(n) O(n)

    • 我们遍历数组一次,因此时间复杂度是线性的。
  • 空间复杂度:
    O ( 1 ) O(1) O(1)

    • 无论输入大小如何,我们只使用常量数量的额外空间。

代码

class Solution(object):def trap(self, height):""":type height: List[int]:rtype: int"""l = 0r = len(height)-1leftmax = height[l]rightmax = height[r]res = 0while l < r:if leftmax < rightmax:l+=1leftmax = max(leftmax, height[l])res += leftmax - height[l]else:r-=1rightmax = max(rightmax, height[r])res += rightmax - height[r]return res

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

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

相关文章

qml:applicationwindow和window的区别

在 Qt Quick 中&#xff0c;ApplicationWindow 和 Window 是用于创建应用程序窗口的两个重要元素。它们之间的区别在于功能和用法上略有不同&#xff1a; ApplicationWindow&#xff1a; ApplicationWindow 是 QtQuick.Controls 模块中的一个元素&#xff0c;用于创建应用程序的…

C语言从头学21——函数

函数是一段可以重复执行的代码。这个定义比较抽象&#xff0c;实际上就是我们常说的子程序。函数的来源有两大块&#xff0c;一是C语言为我们提供的大量函数&#xff0c;如 printf()&#xff0c;它们被声明在各种头文件、库文件中&#xff0c;使用前我们使用 #include 命令把相…

速盾:cdn服务和云服务的区别?

CDN&#xff08;Content Delivery Network&#xff09;服务和云服务在互联网技术中都起到了重要的作用&#xff0c;但是它们的功能和应用场景有所不同。CDN服务主要用于加速静态资源的分发和传输&#xff0c;而云服务则提供了更全面的计算和存储服务。 CDN服务是一种通过将数据…

mediasoup源码分析--channel创建及信令交互

mediasoup源码分析--channel创建及信令交互 概述跨职能图业务流程图代码剖析 概述 在golang实现mediasoup的tcp服务及channel通道一文中&#xff0c;已经介绍过信令服务中tcp和channel的创建&#xff0c;本文主要讲解c中mediasoup的channel创建&#xff0c;以及信令服务和medi…

基于CentOS的全新Linux机器安装Jenkins并生成Allure报告

目录 一、安装Docker 二、安装Docker Compose 三、准备测试用例 四、配置docker-compose.yml 五、启动Jenkins 六、配置Jenkins和Allure插件 七、创建含pytest的Jenkins任务 一、安装Docker 在CentOS上&#xff0c;首先更新包管理工具并安装所需的包。 sudo yum update…

12.3 Go 测试覆盖率

&#x1f49d;&#x1f49d;&#x1f49d;欢迎莅临我的博客&#xff0c;很高兴能够在这里和您见面&#xff01;希望您在这里可以感受到一份轻松愉快的氛围&#xff0c;不仅可以获得有趣的内容和知识&#xff0c;也可以畅所欲言、分享您的想法和见解。 推荐:「stormsha的主页」…

基于Elementui组件,在vue中实现多种省市区前端静态JSON数据展示并支持与后端交互功能,提供后端名称label和id

基于Elementui组件&#xff0c;在vue中实现多种省市区前端静态数据&#xff08;本地JSON数据&#xff09;展示并支持与后端交互功能&#xff0c;提供后端名称label和id 话不多说&#xff0c;先上图 1.支持传递给后端选中省市区的id和名称&#xff0c;示例非常完整&#xff0c…

阿里云 邮件系统DNS域名解析 搭配 postfix+dovecot 邮件服务器

1 创建邮箱域名A记录(一般邮箱客户端&#xff0c;增加pop,imap,stmp 3条记录) 登录阿里云控制台--云解析DNS 2 MX记录 3 SPF记录

SQLAlchemy 连接池

官网SQLAlchemy 是一个流行的 Python SQL 工具包和对象关系映射(ORM)系统,它允许开发者使用 Python 类和对象来与数据库进行交互。在 SQLAlchemy 中,连接池用于管理和复用数据库连接,以提高性能和减少资源消耗。 SQLAlchemy 默认使用 QueuePool 作为连接池实现,但你可以…

【论文复现|智能算法改进】基于多策略的改进蜜獾算法及其应用

目录 1.算法原理2.改进点3.结果展示4.参考文献5.代码获取 1.算法原理 【智能算法】蜜獾算法&#xff08;HBA&#xff09;原理及实现 2.改进点 限制反向学习机制 在挖掘模式和蜂蜜模式不同路径更新的基础上引入限制反向学习机制&#xff0c;在算法迭代时&#xff0c;对当前的…

Spark 面试题(十六)

1. 简述Spark运行时并行度的设置 &#xff1f; 在Spark中&#xff0c;“并行度”&#xff08;Parallelism&#xff09;通常指的是作业中同时执行的任务数量。这个数量决定了在任何给定时间可以有多少任务并发运行&#xff0c;进而影响作业的执行效率和资源利用。以下是设置Spa…

Fegin如何传参form-data文件

Form-data传输file参数&#xff0c;这个大家都比较清楚&#xff0c;那么针对于Fegin参数file参数该如何操作呢&#xff01;下面截图来找到对应的参数关系。 一、之前我们在postMan中是这种传参的&#xff0c;那么如果使用Feigin来传输文件File 二、在Fegin中传form-data参数&a…

C/C++ struct stat介绍

目录 前言 struct stat struct stat 使用 参考 共勉 前言 本文详细介绍了stat结构体的成员变量&#xff0c;以及使用案例&#xff0c;希望能够帮到您。 struct stat struct stat 结构体用于表示文件或者文件系统对象信息的一种结构体的声明&#xff0c;通常在POSIX&#x…

Mac M3 Pro 部署Flink-1.16.3

目录 1、下载安装包 2、解压及配置 3、启动&测试 4、测试FlinkSQL读取hive数据 以上是mac硬件配置 1、下载安装包 官网&#xff1a;Downloads | Apache Flink 网盘&#xff1a; Flink 安装包 https://pan.baidu.com/s/1IN62_T5JUrnYUycYMwsQqQ?pwdgk4e Flink 已…

什么是FOF,什么是信托

基金里面的FOF是什么&#xff1f;请准确专业通俗的解释下 FOF是“Fund of Funds”的缩写&#xff0c;中文称为“基金中的基金”。顾名思义&#xff0c;FOF是一种投资于其他基金的基金产品。与直接投资于股票、债券或货币市场工具的传统基金不同&#xff0c;FOF将其资产投资于一…

时政|精准公交

背景 重庆中心城区开设“小巷公交—便民健康专线”&#xff0c;方便市民就医。“便民健康专线”尊重和回应了市民差异化、个性化需求&#xff0c;见证了公交方面的“思路一变天地宽”。城市的公交汽车竞争力相对不足&#xff0c;客流出现下滑&#xff0c;出现了经营困难&#…

WDF驱动开发-注册表项

驱动程序通常使用一组系统定义的注册表项来存储或访问特定于驱动程序或特定于设备的信息。 驱动程序可能会访问以下注册表项&#xff1a; 1. 参数 键 驱动程序 的参数密钥 可以包含驱动程序的配置信息&#xff0c;可以通过调用 WdfDriverOpenParametersRegistryKey 进行访问。…

【神经网络】深度神经网络如何应用于推荐系统

深度神经网络&#xff08;Deep Neural Networks, DNN&#xff09;在推荐系统中的应用非常广泛&#xff0c;它们能够捕获用户和物品之间复杂的非线性关系&#xff0c;以及用户行为中的潜在模式。以下是一些深度神经网络在推荐系统中的应用方式&#xff1a; 基于内容的推荐&…

【ComfyUI】Stable Diffusion 3 加Controlnet

基于 instantX-research/diffusers_sd3_control: &#x1f917; Diffusers: State-of-the-art diffusion models for image and audio generation in PyTorch and FLAX. (github.com) 和 ZHO-ZHO-ZHO/ComfyUI-SD3-Medium-CN-Diffusers: ComfyUI SD3-Medium ControlNet&#…

html入门综合练习

综合练习 通过实际项目练习可以更好地理解和掌握HTML、CSS和JavaScript。以下是几个综合练习项目的建议&#xff1a; 项目1&#xff1a;个人简历网页 创建一个包含以下内容的个人简历网页&#xff1a; 个人简介&#xff08;姓名、照片、联系方式&#xff09;教育背景工作经…