接雨水

题目描述

给定 n 个非负整数表示每个宽度为 1 的柱子的高度图,计算按此排列的柱子,下雨之后能接多少雨水。
在这里插入图片描述
上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。 感谢 Marcos 贡献此图。

示例:

输入: [0,1,0,2,1,0,1,3,2,1,2,1]
输出: 6

1、 暴力法

/***接雨水,暴力解法* 对于数组中的每个元素,我们找出下雨后水能达到的最高位置,等于两边最大高度的较小值减去当前高度的值。* @param height* @return*/
public int trap(int[] height) {if(height == null || height.length < 2) {return 0;}int leftMax=0, rightMax=0;int count=0;for(int i=1;i<height.length-1;i++) {leftMax=0;rightMax=0;for(int j=0;j<i;j++) {leftMax = Math.max(leftMax, height[j]);}for(int j=height.length-1; j>i;j--) {rightMax = Math.max(rightMax, height[j]);}if(leftMax>0 && rightMax>0 && Math.min(leftMax, rightMax)>height[i]) {count+=(Math.min(leftMax, rightMax) - height[i]);}}return count;}

2、空间换时间

/***接雨水* 用空间换时间,记录下每个节点的左侧最大值,右侧最大值* 对于数组中的每个元素,我们找出下雨后水能达到的最高位置,等于两边最大高度的较小值减去当前高度的值。* @param height* @return*/
public int trap(int[] height) {if(height == null || height.length < 2) {return 0;}int[] leftMax = new int[height.length];for(int i=1;i<height.length;i++) {leftMax[i] = Math.max(leftMax[i-1], height[i-1]);}int[] rightMax = new int[height.length];for(int i=height.length-2;i>=0;i--) {rightMax[i] = Math.max(rightMax[i+1], height[i+1]);}int count=0;for(int i=1;i<height.length-1;i++) {if(Math.min(leftMax[i], rightMax[i])>height[i]) {count+=(Math.min(leftMax[i], rightMax[i])-height[i]);}}return count;}

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

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

相关文章

使用RabbitMQ实现接口补偿

业务背景在我们的日常开发中&#xff0c;经常需要调用第三方接口来进行数据传递&#xff0c;在调用接口的过程中&#xff0c;会因为各种原因导致调用的失败。这时我们希望能有一种机制实现对失败的接口的重复调用&#xff0c;并且能够实现人工干预。实现思路1、当接口调用失败&…

新方法-根据上排给出十个数,在其下排填出对应的十个数

给你10分钟时间&#xff0c;根据上排给出十个数&#xff0c;在其下排填出对应的十个数 要求下排每个数都是先前上排那十个数在下排出现的次数。 上排的十个数如下&#xff1a; 【0&#xff0c;1&#xff0c;2&#xff0c;3&#xff0c;4&#xff0c;5&#xff0c;6&am…

HashMap实现LRU(最近最少使用)缓存更新算法

最近阿里巴巴电话面试被问到了如何使用固定容量的HashMap&#xff0c;实现LRU算法。当时一脸懵逼&#xff0c;平时用HashMap也就用来快速存取数据而已&#xff0c;容量都是不限的。 想了半天&#xff0c;想到对node节点进行扩展&#xff0c;加入引用计数&#xff0c;然后到达指…

集群环境下,你不得不注意的ASP.NET Core Data Protection 机制

引言最近线上环境遇到一个问题&#xff0c;就是ASP.NET Core Web应用在单个容器使用正常&#xff0c;扩展多个容器无法访问的问题。查看容器日志&#xff0c;发现以下异常&#xff1a;System.Security.Cryptography.CryptographicException: The key {efbb9f35-3a49-4f7f-af19-…

程序无法启动ALL_BUILD 拒绝访问

用cmake编译完opencv3.0后&#xff0c;发现编译没有问题&#xff0c;但尝试调试的时候报错无法启动.../ALL_BUILD拒绝访问. 调了很久才解决&#xff0c;方法是&#xff0c;卸载所有无关工程&#xff0c;只保留一个你需要的工程&#xff0c;这时候ZERO_CHECK以及ALL_BUILD都没有…

.NET斗鱼直播弹幕客户端(上)

前言现在直播平台由于弹幕的存在&#xff0c;主播与观众可以更轻松地进行互动&#xff0c;非常受年轻群众的欢迎。斗鱼TV就是一款非常流行的直播平台&#xff0c;弹幕更是非常火爆。看到有不少主播接入 弹幕语音播报器、 弹幕点歌等模块&#xff0c;这都需要首先连接斗鱼弹幕。…

RGB转YUV420

转载自&#xff1a;http://blog.csdn.net/frankiewang008/article/details/6854616 RGB TO YUV转换原理及代码示例 RGB TO YUV转换原理及代码示例YUV 与 YIQ YcrCb对于YUV模型&#xff0c;实际上很多时候&#xff0c;我们是把它和YIQ /…

字符串相乘

题目描述 给定两个以字符串形式表示的非负整数 num1 和 num2&#xff0c;返回 num1 和 num2 的乘积&#xff0c;它们的乘积也表示为字符串形式。 示例 1: 输入: num1 "2", num2 "3" 输出: "6"示例 2: 输入: num1 "123", num2 …

程序员后期,架构师发展路线!

作者:zollty&#xff0c;资深程序员和架构师&#xff0c;私底下是个爱折腾的技术极客&#xff0c;架构师社区合伙人&#xff01;我总结了3个阶段。先说一下各个阶段的感受&#xff1a;1、系统架构阶段&#xff1a;系统架构实际上包括了 业务功能架构 和 技术功能架构。业务上&a…

YUV格式学习

转载自http://blog.csdn.net/searchsun/article/details/2443867 YUV是指亮度参量和色度参量分开表示的像素格式&#xff0c;而这样分开的好处就是不但可以避免相互干扰&#xff0c;还可以降低色度的采样率而不会对图像质量影响太大。YUV是一个比较笼统地说法&#xff0c;针对它…

Flappy Bird游戏python完整源码

通过pygame实现当年风靡一时的flappy bird小游戏。 当前只设定了同样长度的管道&#xff0c;图片和声音文件自行导入。 效果如下&#xff1a; # -*- coding:utf-8 -*- """ 通过pygame实现曾风靡一时的flappybird游戏。 小鸟x坐标不变&#xff0c;画布左移实现…

最短无序连续子数组

题目描述 给定一个整数数组&#xff0c;你需要寻找一个连续的子数组&#xff0c;如果对这个子数组进行升序排序&#xff0c;那么整个数组都会变为升序排序。 你找到的子数组应是最短的&#xff0c;请输出它的长度。 示例 1: 输入: [2, 6, 4, 8, 10, 9, 15] 输出: 5 解释: 你…

【 .NET Core 3.0 】框架之九 || 依赖注入 与 IoC

本文有配套视频&#xff1a;https://www.bilibili.com/video/av58096866/?p5前言1、重要&#xff1a;如果你实现了解耦&#xff0c;也就是 api 层只引用了 IService 和 IRepository 的话&#xff0c;那每次修改 service 层&#xff0c;都需要清理解决方案&#xff0c;重新编译…

内联函数

转载自&#xff1a;http://www.cnblogs.com/socrassi/archive/2009/09/09/1563002.html inline函数 我们看下面的函数&#xff0c;函数体中只有一行语句&#xff1a; double Average(double total, int number){ return total/number; } 定义这么简单的函数…

分布式ID生成方法

1、sharding-jdbc 基于Twitter Snowflake算法实现。但是snowflake算法的缺陷&#xff08;强依赖时间&#xff0c;如果时钟回拨&#xff0c;就会生成重复的ID&#xff09;&#xff0c;sharding-jdbc没有给出解决方案&#xff0c;如果用户想要强化&#xff0c;需要自行扩展&…

10月数据库排行:Microsoft SQL Server分数增加最多

DB-Engines 数据库流行度排行榜 10 月更新已发布&#xff0c;排名前二十如下&#xff1a;这期的数据比较有意思&#xff0c;到了这个月&#xff0c;Microsoft SQL Server 马上扭转局势&#xff0c;成了分数增长最多的一个&#xff0c;与上个月相比其增加了 9.66 分&#xff0c;…

判断两个链表是否相交

如果两链表都无环&#xff0c;直接判断尾是否相交&#xff0c;如果都有环&#xff0c;则判断一链表上指针相遇的节点&#xff08;环入口点&#xff09;在不在另一个链表上。方法如下&#xff1a;【摘要】有一个单链表&#xff0c;其中可能有一个环&#xff0c;也就是某个节点的…

VS Code 1.39 发布!Web 版 VS Code 是否离我们越来越近了?(文末彩蛋)

今天&#xff08;北京时间 2019 年 10 月 10 日&#xff09;&#xff0c;微软发布了 Visual Studio Code 1.39 版本。此版本主要更新的内容包括&#xff1a;Source Control tree view - 可以通过列表或者树状图两种方式来展示被改变的文件。Toggle region folding keyboard sho…

Java引用类型——强引用、软引用、弱引用和虚引用

Java执行GC判断对象是否存活有两种方式其中一种是引用计数。 引用计数&#xff1a;Java堆中每一个对象都有一个引用计数属性&#xff0c;引用每新增1次计数加1&#xff0c;引用每释放1次计数减1。 在JDK 1.2以前的版本中&#xff0c;若一个对象不被任何变量引用&#xff0c;那么…

二叉树分析(两点最大距离)

转载自&#xff1a;http://blog.csdn.net/lalor/article/details/7626678 http://blog.csdn.net/lalor/article/details/7618120 把二叉树看成一个图&#xff0c;父子节点之间的连线看成是双向的&#xff0c;我们姑且定义"距离"为两节点之间边的个数。写…