leetcode 接雨水2_雨水口连接管

leetcode 接雨水2_雨水口连接管题目链接给定 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 个单位的雨水(蓝色部分表示雨水)。示例 2:输入:height = [4,2,0,3,2,5]输出:9 提示:n == height.length0 <= n &lt

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

题目链接

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

输入:height = [4,2,0,3,2,5]
输出:9
 

提示:

n == height.length
0 <= n <= 3 * 104
0 <= height[i] <= 105

题解
单调栈

class Solution { 
   
public:
    int trap(vector<int>& height) { 
   
        stack<int>stk;
        int res = 0;
        for(int i = 0;i < height.size();i ++){ 
   
            int pre = 0;
            while(!stk.empty() && height[stk.top()] <= height[i]){ 
   
                int t = stk.top();
                stk.pop();
                res += (height[t] - pre) * (i - t - 1);
                pre = height[t];
            }
            if(!stk.empty())res += (height[i] - pre) * (i - stk.top() - 1);
            stk.push(i);
        }
        return res;
    }
};
版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/168745.html原文链接:https://javaforall.net

(0)
上一篇 2022年8月8日 下午2:36
下一篇 2022年8月8日 下午2:36


相关推荐

  • 删除数组中指定位置的元素_js数组remove指定元素

    删除数组中指定位置的元素_js数组remove指定元素转载:http://www.php.cn/js-tutorial-412053.html

    2022年8月11日
    13
  • WdatePicker小结

    WdatePicker小结转载自博客园 nbsp donglf 的博客 原博客链接 nbsp https www cnblogs com donglf p 5868999 htmlWdatePic js 日期插件 1 y nbsp nbsp 当前年 nbsp M nbsp nbsp 当前月 nbsp d nbsp nbsp 当前日 nbsp ld 本月最后一天 nbsp H nbsp nbsp 当前时 nbsp m nbsp nbsp 当前分 nbsp s nbsp nbsp 当前秒 2 可以通过配置 minDate 最小日期 和 max

    2026年3月17日
    2
  • DDOS工具集

    DDOS工具集1DDoS 攻击 DDoS 攻击是一种可用于执行分布式拒绝服务攻击的工具 此应用程序可以监控来自众多来源的事件日志 以查找和检测 DDoS 活动 特征 此应用程序可以检测与控制服务器和命令的通信 提供实时响应 可以轻松过滤特定的时间范围 IP 或参数 该工具可帮助您检测命令和控制服务器之间的恶意活动 2PRTGPRTG 网络监控软件以其先进的基础设施管理功能而闻名 该工具使用 SNMP WMI 嗅探 RESTAPIS SQL 等技术监控 IT 基础设施 特征 PRTG 可以通过 ping

    2026年3月26日
    1
  • js 手机号码正则

    js 手机号码正则varphone=document.getElementById(‘phone’).value;if(!(/^1[3456789]\d{9}$/.test(phone))){alert(“手机号码有误,请重填”);returnfalse;}varphone=document.getElementById(‘phon…

    2022年6月11日
    70
  • 谷歌高级搜索技巧_谷歌搜索app技巧

    谷歌高级搜索技巧_谷歌搜索app技巧现在编程几乎就等同于谷歌了(虽然并不是什么好习惯,但很多人就是这么做的)。比如现在你想写个程序来实现某种功能,有99%的可能已经有人完成了并且把代码上传到了StackOverflow或者Github上。办公桌上已经不需要放一堆堆的参考书了,我们只需要把想知道的键入搜索框,然后期待着答案出现在前九个结果中就好了。不过很多人可能不知道,Google隐藏着许多功能强大的搜索技巧。就像掌握快捷

    2022年10月21日
    4
  • 万网免费空间php,免费虚拟主机空间

    万网免费空间php,免费虚拟主机空间免费虚拟主机空间 编辑 概述许多人选择免费虚拟主机搭建自己的网站或 Web 技术 事实上免费虚拟主机存在很大风险 如果你需要可靠的 安全的 能快速加载服务的 有技术保障支持的服务 建议你准备一些预算 到正规的买可靠的虚拟主机空间 一 什么是免费虚拟主机免费虚拟主机是指 IDC 服务商 免费 为站长提供网页寄存服务 免费虚拟主机用于制作免费个人网站 是学习网页设计的好方法 虚拟主机就是指网站空间 是在网

    2026年3月26日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号