zoukankan      html  css  js  c++  java
  • [leetcode]42. Trapping Rain Water雨水积水问题

    Given n non-negative integers representing an elevation map where the width of each bar is 1, compute how much water it is able to trap after raining.


    The above elevation map is represented by array [0,1,0,2,1,0,1,3,2,1,2,1]. In this case, 6 units of rain water (blue section) are being trapped. Thanks Marcos for contributing this image!

    Example:

    Input: [0,1,0,2,1,0,1,3,2,1,2,1]
    Output: 6

    题意:

    给定一个地形,计算能存多少雨水。

    思路:

    1. 扫数组,找到最高柱子并以此为中心,将数组分为两半。 

    2. 对左半部分而言,可以想象右边一定有堵墙,只需要每次更新leftMost就能决定water大小

    3. 对右半部分而言,同理。

    代码:

     1 class Solution {
     2     public int trap(int[] height) {
     3         // find hightest bar 
     4         int peak_index = 0; 
     5         for(int i = 0; i < height.length; i++){
     6             if(height[i] > height[peak_index]){
     7                 peak_index = i; 
     8             }
     9         } 
    10         // 1. from left to peak_index
    11         int leftMostBar = 0; 
    12         int water = 0; 
    13         for(int i = 0; i < peak_index; i++){
    14             if (height[i] > leftMostBar){
    15                 leftMostBar = height[i];
    16             }else{
    17                 water  = water + leftMostBar - height[i]; 
    18             }
    19         }
    20         
    21         // 2. from right to peak_index
    22         int rightMostBar = 0; 
    23         for(int i = height.length - 1; i > peak_index; i--){
    24             if (height[i] > rightMostBar){
    25                 rightMostBar = height[i];
    26             }else{
    27                 water  = water + rightMostBar - height[i]; 
    28             }
    29         }
    30         return water;        
    31     }
    32 }
  • 相关阅读:
    vi命令文件编辑
    Linux vi/vim编辑器常用命令与用法总结
    常用vi编辑器命令行
    在AspNetMvc中使用日志面板. Logdashboard 1.1beta
    Abp中使用可视化的日志面板
    使用logdashboard进行可视化的日志追踪
    可视化面板LogDashboard使用log4net源
    LogDashboard 1.0.4 版本发布
    什么是LogDashboard?
    使用logdashboard查看可视化日志
  • 原文地址:https://www.cnblogs.com/liuliu5151/p/9207441.html
Copyright © 2011-2022 走看看