Leetcode 11 盛最多水的容器

题目

分析

双指针的问题,移动的时机判断

代码

 public static void main(String[] args) {
        int[] arr={1,8,6,2,5,4,8,3,7};
        int res = maxArea(arr);
        System.out.println(res);
    }
    public static int maxArea(int[] height) {
        int start=0;
        int end=height.length-1;
        int max=0;
        while(start!=end)
        {
            int h=height[start]<height[end]?height[start]:height[end];
            int cur=h*(end-start);
            max=Math.max(max,cur);
            if(h==height[start])
            {
                start++;
            }else
            {
                end--;
            }
        }
        return max;
    }

学习情况

1次

全部评论

相关推荐

不愿透露姓名的神秘牛友
07-08 14:10
点赞 评论 收藏
分享
强大的马里奥:不太可能,我校计算机硕士就业率99%
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务