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

leetcode42雨水

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

法一:前缀和
求能装多少水,即左右两边木板高度的最小值减去数组元素。左边木板高度即左区间最大高度,右边木板高度即右区间最大高度。第一个数组存储从最左边到第i个位置的最大高度(前缀最大值),第二个数组存储从最右边到第i的位置的最大高度(后缀最大值)。对于当前位置的前缀最大值 = max(前一个位置的前缀最大值,当前位置的最大高度)。每一个位置的前后缀数组里的值的最小值减去数组中的数值即水

classSolution{intpre_max[20010];intsuf_max[20010];public:inttrap(vector<int>&nums){intn=nums.size();pre_max[0]=nums[0];for(inti=1;i<n;++i)pre_max[i]=max(pre_max[i-1],nums[i]);suf_max[n-1]=nums[n-1];for(inti=n-2;i>=0;--i)suf_max[i]=max(suf_max[i+1],nums[i]);intret=0;for(inti=0;i<n;++i){ret+=min(pre_max[i],suf_max[i])-nums[i];}returnret;}};

法二:优化为双指针(好处,不用创建数组)
前缀最大值 > 后缀最大值,则最大高度为后缀最大值,水量为这个最大高度减去数组元素,右指针左移

classSolution{public:inttrap(vector<int>&nums){intn=nums.size();intpre_max=0,suf_max=0;intleft=0,right=n-1;intret=0;while(left<=right){pre_max=max(pre_max,nums[left]);suf_max=max(suf_max,nums[right]);if(pre_max<suf_max){ret+=pre_max-nums[left++];}elseret+=suf_max-nums[right--];}returnret;}};
http://www.jsqmd.com/news/880574/

相关文章:

  • 2026年当下广东省冰花漆采购指南:聚焦云勋新材料科技有限公司 - 2026年企业推荐榜
  • 2026年至今,上海新风系统源头服务专家:合宜人居深度解析 - 2026年企业推荐榜
  • 千年盛世手游官网下载:千年盛世最新官方下载渠道
  • Pillow 10升级后,你的图像标注代码还好吗?从getsize到getbbox的迁移避坑指南
  • 求推荐靠谱的孩子独立北京行,老师负责的研学机构 - 品牌2025
  • ge:昇腾CANN的图引擎架构剖析
  • 2026排污许可证办理全解析:北京排水排污许可证/北京酒店特行许可证审批/城镇污水排入排水管网许可证/宾馆特行许可证/选择指南 - 优质品牌商家
  • 四川热轧H型钢公司、正规钢材生产供货厂商 - 四川盛世钢联营销中心
  • Qt6.5数控加工CAM框架实战:基于工厂模式与分层架构的CamCore完整实现
  • cann-learning-hub:昇腾CANN社区的学习中心
  • 办公场景横向测评:GPT-5.5、DeepSeek、Gemini 处理公文优劣对比
  • MNIST识别项目复盘:除了准确率97%,我们更应该关注数据预处理与损失函数的选择
  • 【无标题】学生用户画像—考勤主题扩建标签构建
  • 2026年5月江苏物业选型指南:聚焦诚信服务商的核心价值与选择逻辑 - 2026年企业推荐榜
  • 不用开WPS会员了!这一款电子发票批量打印工具:支持排版 + OCR识别,完全免费!
  • 离线语音识别与物联网在智能家居中的应用与优化
  • 深度强化学习与控制 课程 第二周 课程总结
  • Go语言内存泄漏:pprof与监控
  • 苍穹外卖day4
  • 3D光学流技术在机器人动作生成中的应用与优化
  • 深度学习落地经验:从情感分析业务中学到的5个关键教训
  • SVN SSL证书验证失败的根源与四关卡排障法
  • 事业单位教育类考试人名考点速记笔记
  • 从集合运算到代码:一文搞懂Jaccard系数,附Python/NumPy/Pandas三种实现方法对比
  • Java基础总结(快速入门版)
  • 从黑猩猩内战到人类关系:互动是系统的命脉,遗忘是文明的暗礁
  • 8051 XDATA分页配置与内存管理实战
  • Nsight System和Compute命令行
  • 小学期第二周学习笔记
  • BP算法(反向传播)初步学习