题目描述
给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。
找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。
返回容器可以储存的最大水量。
说明:你不能倾斜容器。
代码
area = (r-l)*min(h[l], h[r]),基于贪心的思想,先让l在区间的左端、r在区间右端,如果要缩小[l,r]区间的长度,就需要先滑动min(h[l], h[r]),因为希望把短的那条边替换成长的。
class Solution {
public int maxArea(int[] height) {
int n = height.length;
int l = 0, r = n-1, area = 0;
while(l<r){
area = Math.max(area, (r-l)*Math.min(height[l], height[r]));
if(height[l]>height[r]) r--;
else l++;
}
return area;
}
}