Java盛最多的水leetcode

给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0) 和 (i, height[i]) 。

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

说明:你不能倾斜容器。

class Solution {
    public int maxArea(int[] height) {
        int start = 0,end = height.length - 1;
        int ans = 0;
        while(start < end){
            int area = Math.min(height[start],height[end]) * (end - start);
            ans = Math.max(area,ans);

            if(height[start] <= height[end]){
                //推荐++i,i++在计算过程中会多一个缓存变量保存中间值,使速度变慢
                ++start;
            }else{
                --end;
            }
        }
        return ans;
    }
}

你可能感兴趣的:(Java算法leetcode,java,算法)