【LeetCode】盛最多水的容器【双指针+贪心 寻找最大面积】

给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) 。在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0)。找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

说明:你不能倾斜容器,且 n 的值至少为 2。

图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。

question_11

示例:

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

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/container-with-most-water


分析:头尾指针+贪心思想

两线段之间形成的区域总是会受到其中较短那条长度的限制。此外,两线段距离越远,得到的面积就越大。

应用贪心的思想,分为头指针和尾指针,头指针和尾指针中指向元素较小的指针需要进行移动(头指针加加,尾指针减减),因为盛水的多少是由短板决定的,所以短板需要移动,以便尽可能的获得大的面积,即使两块木板见间隔的距离在逐渐变小也没有关系,取每次得到的面积的最大值就是最大的盛水面积

时间复杂度:O(N)

空间复杂度:O(1)

官方题解,有配图,更容易懂:https://leetcode-cn.com/problems/container-with-most-water/solution/sheng-zui-duo-shui-de-rong-qi-by-leetcode/

复制代码
class Solution {
public:
int maxArea(vector<int>& v)
{
    int n=v.size();
    int start=0;
    int end=n-1;
    int ans=0;
    while(start<=end)
    {
        int x=min(v[start],v[end])*(end-start);
        ans=max(ans,x);
        if(v[start]<v[end])
            start++;
        else
            end--;
    }
    return ans;
}
};
复制代码
posted @   西*风  阅读(294)  评论(0编辑  收藏  举报
编辑推荐:
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
阅读排行:
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南
历史上的今天:
2018-08-02 POJ 1949 Chores (很难想到的dp)
2018-08-02 hdu 1520 Anniversary party(第一道树形dp)
2018-08-02 (CodeForces - 5C)Longest Regular Bracket Sequence(dp+栈)(最长连续括号模板)
点击右上角即可分享
微信分享提示