题解 | #接雨水问题,双指针#

接雨水问题

http://www.nowcoder.com/practice/31c1aed01b394f0b8b7734de0324e00f

import java.util.*;


public class Solution {
    /**
     * max water
     * @param arr int整型一维数组 the array
     * @return long长整型
     */
    public long maxWater (int[] arr) {
        if(arr == null || arr.length < 3) return 0 ;
        int left = 0 ;//标记左边界
        int right = arr.length - 1 ;//标记右边界
        int cur = 0 ;//当前指针
        int count = 0 ;//记录体积
        while(left < right) {
            //求出短板
            int min = arr[left] < arr[right] ? arr[left] : arr[right] ;
            if(min == arr[left]) {//如果短板是左边,就从左边开始计算,直到找到一个更长的板
                cur = left + 1 ;
                while(cur <= right && arr[cur] <= min) {
                    count += (min - arr[cur++]) ;
                }
                left = cur ;
            } else {//长板是右边,类似。
                cur = right - 1 ;
                while(cur >= left && arr[cur] <= min) {
                    count += (min - arr[cur--]) ;
                }
                right = cur ;
            }
        }
        return count ;
    }
}

一个菜鸟的算法刷题记录 文章被收录于专栏

分享一个菜鸟的成长记录

全部评论

相关推荐

07-13 14:45
南华大学 Java
北斗导航Compas...:英文和中文之间加个空格,有的句子有句号 有的没。其他没啥问题
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务