中等
提示
给定一个长度为 n
的整数数组 height
。有 n
条垂线,第 i
条线的两个端点是 (i, 0)
和 (i, height[i])
。
找出其中的两条线,使得它们与 x
轴共同构成的容器可以容纳最多的水。
返回容器可以储存的最大水量。
说明:你不能倾斜容器。
示例 1:
输入:[1,8,6,2,5,4,8,3,7]
输出:49
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。
示例 2:
输入:height = [1,1]
输出:1
提示:
n == height.length
2 <= n <= 105
0 <= height[i] <= 104
1. 题解
class Solution {
public int maxArea(int[] height) {
int ans = 0;
int left = 0;
int right = height.length - 1;
while (left < right) {
int area = (right - left) * Math.min(height[left], height[right]);
ans = Math.max(ans, area);
if (height[left] < height[right]) {
// height[left] 与右边的任意线段都无法组成一个比 ans 更大的面积
left++;
} else {
// height[right] 与左边的任意线段都无法组成一个比 ans 更大的面积
right--;
}
}
return ans;
}
作者:灵茶山艾府
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
2、核心:为什么双指针移动是正确的?
双指针法的关键是每次移动较矮的指针,这一步的逻辑需要重点理解:
假设当前左指针left
的高度为h1
,右指针right
的高度为h2
,且h1 < h2
(左指针更矮)。此时:
当前容器的高度由h1
决定(因为h1
更矮),底边长为right - left
。
如果此时移动右指针(right--
),新的底边长会变小(right-1 - left
),而新的高度最多还是
h1
(因为右指针移动后新的高度可能比h2
小,但h1
仍然是较矮的那个)。因此,新的面积一定会小于等于当前面积(底变小,高不变或更小)。
而如果移动左指针(left++
),虽然底边长也会变小(right - (left+1)
),但新的左指针高度可能比h1
大,此时新的高度可能增大,从而可能得到更大的面积。