博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
算法题——接雨水
阅读量:2344 次
发布时间:2019-05-10

本文共 1303 字,大约阅读时间需要 4 分钟。

1. 本题知识点

双指针

2. 题目描述

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

在这里插入图片描述

上面是由数组 [0,1,0,2,1,0,1,3,2,1,2,1] 表示的高度图,在这种情况下,可以接 6 个单位的雨水(蓝色部分表示雨水)。

示例 1:

输入:

[0,1,0,2,1,0,1,3,2,1,2,1]

输出:

6

3. 解题思路

找出最高点,分别从两边往最高点遍历:如果下一个数比当前数小,说明可以接到水

在这里插入图片描述

4. 代码

public class Solution {
public int trap(int[] height) {
int result = 0; int maxValue = 0; int maxIndex = 0; // 取数组最大值及下标 for (int i = 0; i < height.length; i++) {
if (height[i] >= maxValue) {
maxValue = height[i]; maxIndex = i; } } // 左半部分处理 for (int left = 0; left < maxIndex; left++) {
for (int i = left + 1; i <= maxIndex; i++) {
if (height[i] < height[left]) {
result += height[left] - height[i]; } else {
left = i; } } } // 右半部分处理 for (int right = height.length - 1; right > maxIndex; right--) {
for (int i = right - 1; i >= maxIndex; i--) {
if (height[i] < height[right]) {
result += height[right] - height[i]; } else {
right = i; } } } return result; }}

转载地址:http://jcjvb.baihongyu.com/

你可能感兴趣的文章
spring 简述
查看>>
HttpClient-03Http状态管理
查看>>
spring cloud 启动报错-must be declared as an @AliasFor [serviceId], not [name].
查看>>
常用软件下载地址
查看>>
修改spring boot 启动logo
查看>>
spring boot-启动及配置文件
查看>>
HttpsURLConnection 安全传输(HTTPS--Secure Hypertext Transfer Protocol-安全超文本传输协议)...
查看>>
ASP.NET跨页面传值的技巧
查看>>
ASP.NET页面之间传递值解析
查看>>
我要学ASP.NET MVC 3.0(八): MVC 3.0 传递和保存你的Model
查看>>
我要学ASP.NET MVC 3.0(九): MVC 3.0 验证你的Model
查看>>
我要学ASP.NET MVC 3.0(十): MVC 3.0 使用 Forms身份验证
查看>>
我要学ASP.NET MVC 3.0(十一): MVC 3.0 使用筛选器
查看>>
ASP.NET MVC3、Pager 分页
查看>>
在 ASP.NET MVC 中创建自定义 HtmlHelper 控件
查看>>
MSDN---扩展方法 (C# 方法中的this参数)
查看>>
我要学ASP.NET MVC 3.0(十四): MVC 3.0 实例系列之创建数据表格
查看>>
我要学ASP.NET MVC 3.0(十五): MVC 3.0 实例系列之表格的排序
查看>>
我要学ASP.NET MVC 3.0(十七): MVC 3.0 实例之表格中数据的筛选
查看>>
Displaying a Sorted, Paged, and Filtered Grid of Data in ASP.NET MVC
查看>>