编程语言
首页 > 编程语言> > letcode算法--8.盛水最多的容器

letcode算法--8.盛水最多的容器

作者:互联网

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

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

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

说明:你不能倾斜容器。

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/container-with-most-water
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

方法一:暴力解法

时间超时

class Solution {
    public int maxArea(int[] height) {
        int len = height.length;
        if (len == 0) return 0;
        if (len == 1) return 0;
        int max = 0;
        for (int i = 0; i < len; i ++){
            for (int j = i+1; j <len; j ++){
                int temp = 0;
                int hig = Math.min(height[i],height[j]);
                temp = hig * (j - i);
                if (max<temp) max=temp;
            }
        }
        return max;
    }
}

方法一:双指针解法

class Solution {
    public int maxArea(int[] height) {
        int len = height.length;
        if (len == 0) return 0;
        if (len == 1) return 0;
        int max = 0;
        int i = 0;
        int j = len-1;
        while (i<j){
            int hig = Math.min(height[i],height[j]);
            int temp = hig * (j - i);
            if (max<temp) max=temp;
            if (height[i] <= height[j])++i;
            else --j;
        }
        return max;
    }
}

 

标签:容器,return,盛水,--,len,height,int,length,letcode
来源: https://www.cnblogs.com/xinger123/p/16651111.html