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

    }
};
相关推荐
Dream it possible!19 分钟前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树中第 K 小的元素(86_230_C++_中等)
c++·leetcode·面试
sin_hielo1 小时前
leetcode 2872
数据结构·算法·leetcode
dragoooon341 小时前
[优选算法专题八.分治-归并 ——NO.49 翻转对]
算法
AI科技星1 小时前
为什么宇宙无限大?
开发语言·数据结构·经验分享·线性代数·算法
Zero-Talent2 小时前
位运算算法
算法
不穿格子的程序员2 小时前
从零开始刷算法——双指针-三数之和&接雨水
算法·双指针
无限进步_3 小时前
C语言数组元素删除算法详解:从基础实现到性能优化
c语言·开发语言·windows·git·算法·github·visual studio
松涛和鸣3 小时前
16、C 语言高级指针与结构体
linux·c语言·开发语言·数据结构·git·算法
Booksort3 小时前
【LeetCode】算法技巧专题(持续更新)
算法·leetcode·职场和发展
OJAC1113 小时前
2026高校毕业生1270万!但这些学生却被名企用高薪“提前预定”!
算法