一、题目描述
给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。
找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。
返回容器可以储存的最大水量。
说明:你不能倾斜容器。
二、解答
1.思路
横坐标距离越远,可能装水的容量越多,从坐标两端开始计算装水容量,将高度较低的一侧向内移动,将每次计算的值进行比较,最后返回最大值。
2.代码
代码如下(示例):
int maxArea(int* height, int heightSize) {
int left=0,right=heightSize-1;
int erea=0,ret=0;
while(left<right){
if(height[left]<height[right]){
erea =(right-left)*h eight[left];
left++;
}else{
erea =(right-left)*height[right];
right--;
}
if(erea>ret){
ret=erea;
}
}
return ret;
}