力扣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;

    }
};
相关推荐
程序员Xu10 分钟前
【LeetCode热题100道笔记】二叉搜索树中第 K 小的元素
笔记·算法·leetcode
THMAIL1 小时前
机器学习从入门到精通 - 数据预处理实战秘籍:清洗、转换与特征工程入门
人工智能·python·算法·机器学习·数据挖掘·逻辑回归
Kevinhbr1 小时前
CSP-J/S IS COMING
数据结构·c++·算法
蕓晨2 小时前
set的插入和pair的用法
c++·算法
THMAIL2 小时前
深度学习从入门到精通 - AutoML与神经网络搜索(NAS):自动化模型设计未来
人工智能·python·深度学习·神经网络·算法·机器学习·逻辑回归
金古圣人2 小时前
hot100 滑动窗口
数据结构·c++·算法·leetcode·哈希算法
kebeiovo2 小时前
算法-二叉树的序列化与反序列化
算法
蒹葭玉树2 小时前
【C++上岸】C++常见面试题目--算法篇(第二十期)
c++·算法·面试
JJJJ_iii2 小时前
【左程云算法03】对数器&算法和数据结构大致分类
数据结构·算法·分类
轮到我狗叫了3 小时前
牛客.小红的子串牛客.kotori和抽卡牛客.循环汉诺塔牛客.ruby和薯条
java·开发语言·算法