力扣11:盛水最多的容器

力扣11:盛水最多的容器

题目

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

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

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

说明:你不能倾斜容器。

思路

最大水量其实就是容积,而容积我们可以用长×宽来表示。

所以这道题我们维护两个变量从而来表达长度和宽度,再定义一个最大容积的变量在宽度和长度变化后取最大值。

代码

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        //容积等于长度×宽度
        //所以我们只需要找到相乘最高的容积即可
        int n = height.size();
        int prev = 0;
        int cur = n-1;
        int maxvol = 0;

        while(prev < cur)
        {
            //长度是下标相减
            int length = cur - prev;
            //宽度是下标对应的值的最小值
            int width = min(height[cur],height[prev]);
            maxvol = max(maxvol,length*width);
            if(height[prev] < height[cur])
            {
                prev++;
            }
            else
            {
                cur--;
            }
        }
        return maxvol;

    }
};
相关推荐
我命由我123454 小时前
Photoshop - Photoshop 工具栏(5)多边套索工具
笔记·学习·ui·职场和发展·photoshop·ps·美工
_dindong5 小时前
动规:回文串问题
笔记·学习·算法·leetcode·动态规划·力扣
wangwangmoon_light6 小时前
0.0 编码基础模板
java·数据结构·算法
共享家95276 小时前
Leetcode刷题
算法·leetcode·职场和发展
simon_skywalker6 小时前
第7章 n步时序差分 n步时序差分预测
人工智能·算法·强化学习
山,离天三尺三6 小时前
基于LINUX平台使用C语言实现MQTT协议连接华为云平台(IOT)(网络编程)
linux·c语言·开发语言·网络·物联网·算法·华为云
flashlight_hi7 小时前
LeetCode 分类刷题:74. 搜索二维矩阵
python·算法·leetcode·矩阵
小年糕是糕手7 小时前
【数据结构】算法复杂度
c语言·开发语言·数据结构·学习·算法·leetcode·排序算法
程序员-King.7 小时前
day86——有效的字母异位词(LeetCode-242)
算法·字符串
kalvin_y_liu8 小时前
【MES架构师与C#高级工程师(设备控制方向)两大职业路径的技术】
开发语言·职场和发展·c#·mes