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 ;
}
}