题解 | 盛水最多的容器

盛水最多的容器

https://www.nowcoder.com/practice/3d8d6a8e516e4633a2244d2934e5aa47

import java.util.*;


public class Solution {
    /**
     * 双指针 加 贪心算法
     * 从两头往开始这个时候宽度最宽
     * 往中间移动的时候,宽度变小,保留较大的高,较小的高往中间移动早到一个比之前大的,计算面积
     *
     * @param height
     * @return
     */
    public int maxArea(int[] height) {
        if (height == null || height.length == 0) {
            return 0;
        }
        int left = 0;
        int right = height.length - 1;
        int maxArea = 0;
        while (left < right) {
            if (height[left] <= height[right]) {
                int area = height[left] * (right - left);
                left++;
                maxArea = Math.max(maxArea, area);
                continue;
            }
            if (height[right] < height[left]) {
                int area = height[right] * (right - left);
                right--;
                maxArea = Math.max(maxArea, area);
            }
        }
        return maxArea;
    }
}

全部评论

相关推荐

点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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