题解 | #盛水最多的容器#

盛水最多的容器

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

跳过指针移动过程中经过的比该循环初始时的值还要小的位置,这些位置不可能是最大容量,因为底面长度和边长都在缩短。

static const auto io_sync_off = []() {
    std::ios::sync_with_stdio(false); //关闭输入输出
    std::cin.tie(nullptr);            //取消两个stream绑定
    std::cout.tie(
        nullptr);           //取消cin 和 cout之间的绑定,加快执行效率
    return nullptr;
}
();
class Solution {
  public:
    int maxArea(vector<int>& height) {
        if (height.size() < 2) {
            return 0;
        }
        int res = 0, left = 0, right = height.size() - 1;
        while (left < right) {
            if (height[left] < height[right]) {
                res = max(res, height[left] * (right - left));
                while (height[left + 1] <= height[left]) {
                    left++;
                }
                left++;
            } else {
                res = max(res, height[right] * (right - left));
                while (height[right - 1] <= height[right]) {
                    right--;
                }
                right--;
            }
        }
        return res;
    }
};

全部评论

相关推荐

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

创作者周榜

更多
牛客网
牛客企业服务