LeetCode 11. 盛最多水的容器

目录

原题

盛最多水的容器

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

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

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

说明:不能倾斜容器。

示例 1 :

输入:[1,8,6,2,5,4,8,3,7]

输出:49

示例 2 :

输入:height = [1,1]

输出:1

题目解析

本题要想清楚题目的要求,就需要对题目给出的示例和图片进行分析了:

示例 1:

在示例 1 中,height数组中有 9 个值,对应着图片中 9 条垂线每一条的高度,选出其中的两条垂线,然后用这两条垂线组成一个容器并计算它的容量,我们要做的就是选出容器的最大容量并返回

算法原理

根据示例 1 给出的图片可知,两条垂线组成一个容器时,容器的高度 h 取最短的那一条,容器的宽度 w 取两条垂线对应的下标的差,容器的容量 v = 容器的高度 h * 容器的宽度 w

对于这道题,是存在单调性的,如果我们在左右端点设置两个指针,并让两个指针向中间移动时,我们会发现,宽度是一直在减少的,但是高度可能增加,可能减少,也可能不变。根据容量的式子,我们可以知道:

  • 容器的高度 h 减少,容器的宽度 w 减少时,容器的容量 v 也会减少
  • 容器的高度 h 不变,容器的宽度 w 减少时,容器的容量 v 也会减少
  • 容器的高度 h 增加,容器的宽度 w 减少时,容器的容量 v 可能增加,也可能减少

所以,我们可以设置两个指针 left 和 right,让 left 指向最左侧的数,让 right 指向最右侧的数,先通过 left 和 right 指向的两个数中的最小数(高度)以及下标之差(宽度)计算出一个容量保存起来,再比较 left 和 right 指向的值,若 left 指向的更小,left++,否则 right--,如果指向的值相同,则移动哪个都可以,因为小值的后方或前方可能有更大的值,所以让较小的移动,寻找更大的高度并继续计算容量,当容量比之前的大就进行更新,直到 left 与 right 相遇为止,就算出了最大容量

代码实现

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        int left = 0;
        int right = height.size() - 1;
        int capacity = 0;

        while (left != right)
        {
            //取最短的木板
            int minHeight = height[left] <= height[right] ?  height[left] : height[right];
            //当前的容量更大,更新容量
            if (minHeight * (right - left) > capacity)
            {
                capacity = minHeight * (right - left);
            }

            //排除小的值
            if (height[left] <= height[right])
            {
                left++;
            }
            else
            {
                right--;
            }
        }

        return capacity;
    }
};
相关推荐
wuhen_n3 分钟前
JavaScript内置数据结构
开发语言·前端·javascript·数据结构
努力学算法的蒟蒻3 分钟前
day79(2.7)——leetcode面试经典150
算法·leetcode·职场和发展
不会代码的小测试6 分钟前
UI自动化-POM封装
开发语言·python·selenium·自动化
2401_841495648 分钟前
【LeetCode刷题】二叉树的层序遍历
数据结构·python·算法·leetcode·二叉树··队列
AC赳赳老秦10 分钟前
2026国产算力新周期:DeepSeek实战适配英伟达H200,引领大模型训练效率跃升
大数据·前端·人工智能·算法·tidb·memcache·deepseek
roman_日积跬步-终至千里12 分钟前
【Java并发】Java 线程池实战:警惕使用CompletableFuture.supplyAsync
java·开发语言·网络
lsx20240617 分钟前
C++ 基本的输入输出
开发语言
CodeSheep程序羊29 分钟前
拼多多春节加班工资曝光,没几个敢给这个数的。
java·c语言·开发语言·c++·python·程序人生·职场和发展
独好紫罗兰30 分钟前
对python的再认识-基于数据结构进行-a002-列表-列表推导式
开发语言·数据结构·python
2401_8414956434 分钟前
【LeetCode刷题】二叉树的直径
数据结构·python·算法·leetcode·二叉树··递归