当前位置: 首页 > news >正文

下雨了,算法帮你算能接多少水 ☔

求解思路

这道题的关键在于理解每个位置能接多少水。

想象你站在某个位置i上,这个位置能接住的水量取决于什么呢?

其实就是左右两边的"围墙"能托住多高的水。

具体来说就是左右两边最高的柱子,其中,这两个高度中较矮的那个决定了水位线,然后用这个水位线减去当前位置的高度,就是这个位置能接的水量。

如果当前位置本身就比水位线高,那自然接不住水。

所以问题就转化成了:

对于每个位置,我们需要知道它左边的最大值和右边的最大值,然后取两者的较小值作为水位,最后累加每个位置能接的水量即可。

方法1

既然需要知道每个位置左右两边的最大值,最直接的想法就是提前算好

publicstaticinttrap(int[]nums){intn=nums.length;int[]lmax=newint[n];int[]rmax=newint[n];// 计算每个位置左边的最大值lmax[0]=nums[0];for(inti=1;i<n;i++){lmax[i]=Math.max(lmax[i-1],nums[i]);}// 计算每个位置右边的最大值rmax[n-1]=nums[n-1];for(inti=n-2;i>=0;i--){rmax[i]=Math.max(rmax[i+1],nums[i]);}// 累加每个位置能接的水量intans=0;for(inti=1;i<n-1;i++){ans+=Math.max(0,Math.min(lmax[i-1],rmax[i+1])-nums[i]);}returnans;}

方法2

假设左边最大值小于等于右边最大值,那么左指针位置的接水量只取决于左边最大值,右边再高也没用。反之亦然。

publicstaticinttrap(int[]nums){intl=1,r=nums.length-2;intlmax=nums[0],rmax=nums[nums.length-1];intans=0;while(l<=r){if(lmax<=rmax){// 左边矮,左指针位置的水量确定ans+=Math.max(0,lmax-nums[l]);lmax=Math.max(lmax,nums[l++]);}else{// 右边矮,右指针位置的水量确定ans+=Math.max(0,rmax-nums[r]);rmax=Math.max(rmax,nums[r--]);}}returnans;}

如果觉得有帮助,欢迎点赞、关注、转发~

http://www.cnnetsun.cn/news/70626.html

相关文章:

  • 一口气解释清楚转换流存在的原因
  • 从卧床不起到健步如飞 退休老阿姨用机器人治腰突的亲身体验!
  • Java毕设项目:基于springboot新能源汽车销售管理系统基于Java Web的新能源汽车信息咨询服务(源码+文档,讲解、调试运行,定制等)
  • Java毕设项目:基于springboot高校体育运动会比赛系统(源码+文档,讲解、调试运行,定制等)
  • uos server 1070e在线软件仓库源整理记录
  • 谷歌镜像站同步更新:Qwen-Image全球加速访问
  • 使用Docker Compose快速部署FLUX.1-dev镜像的5个步骤
  • 腾讯混元HunyuanVideo-Foley模型上线GitHub,开启音画同步新纪元
  • npm publish发布基于Qwen-Image的封装库到公共仓库
  • 冥想第一千七百三十二天(1732)
  • 冥想第一千七百三十三天(1733)
  • Qwen3-8B vs 其他8B模型:开源大模型性能对比实测
  • java计算机毕业设计生活用品供应管理系统的设计与实现 基于SpringBoot的社区日用品采购平台的设计与实现 面向校园的日用杂货线上供应系统的设计与实现
  • 干货!大数据数据增强的实际应用技巧
  • 大数据领域中Power BI与其他工具的对比分析
  • ensp下载官网被屏蔽?国内镜像站提供备份资源
  • 付费墙绕过技术深度解析:Bypass Paywalls Clean实现原理与应用指南
  • 小米运动步数自动同步工具:2025年免费刷步数完整教程
  • Ubuntu安装GNOME桌面增强PyTorch开发体验
  • gpt-oss-20b能否用于文本摘要任务?实测效果报告
  • 3步搞定!网易云NCM音乐格式转换全攻略
  • Flutter 跨端开发进阶:可复用自定义组件封装与多端适配实战(移动端 + Web + 桌面端)
  • Qwen3-VL-30B在金融报表图表解析中的精准度表现测试
  • Ruby CGI 编程
  • 【直接抄作业】2025 网安工程师入门到精通:零基础全流程(收藏即够用)
  • 8个降AI率工具推荐,本科生开题报告必备
  • C++ 程序流程结构-循环结构-for循环
  • BOE(京东方)发布智能体集群 多智能体协同重塑AI+显示新未来
  • 国产POE降压恒压芯片方案选型:48v-52v输入转5v-12v/1-3A电源芯片
  • 9个研究生论文写作工具,AI工具推荐解决发表难题!