码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LeetCode42:接雨水


    LeetCode42:接雨水

    给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。

    示例 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 个单位的雨水(蓝色部分表示雨水)。

    关键词:单调栈,栈中存放元素为数组下标,计算雨水的条件:当前遍历到的数组元素数值 >  栈顶元素所指代的数组元素数值

    思路:使用单调栈存放数组下标,而且栈底到栈顶所指代的数组元素数值是依次递减的。每次当遇到:当前遍历到的数组元素的数值 > 栈顶元素所指代的数组元素的数值的时候,就计算 雨水,直到栈顶元素所指代的数组元素的数值 不大于 当前遍历到的数组元素的数值为止。然后将当前数组元素的下标入栈,继续for循环遍历下一个数组元素,直到循环结束。

    代码实现:

    1. class Solution {
    2. public int trap(int[] height) {
    3. if (height == null || height.length == 0) return 0;
    4. Stack stack = new Stack<>();
    5. int res = 0;
    6. for (int i = 0; i < height.length; ++i) {
    7. while (!stack.isEmpty() && height[i] > height[stack.peek()]) {
    8. int index = stack.pop();
    9. if (stack.isEmpty()) {
    10. break;
    11. }
    12. int width = i - stack.peek() - 1;
    13. int length = Math.min(height[i], height[stack.peek()]) - height[index];
    14. res += width * length;
    15. }
    16. stack.push(i);
    17. }
    18. return res;
    19. }
    20. }

  • 相关阅读:
    代码随想录算法训练营第四十八天|198. 打家劫舍、213. 打家劫舍 II、337. 打家劫舍 III
    如何在GitHub正确提PR(Pull Requests),给喜欢的开源项目贡献代码
    通过大型语言模型 (LLM)降低运营成本
    初识MySQL
    数字信号处理-9-离散余弦变换
    浅谈选择示波器时的“5倍法则”
    Java之线程池的详细解析
    iview form组件,当formItem嵌套使用时,formData会是多层结构的json数据,导致async-validator验证插件失效
    初级篇—第七章数据处理增删改
    Say Goodbye to OOM Crashes
  • 原文地址:https://blog.csdn.net/RitaAndWakaka/article/details/126372457
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号