[双指针] 4. 力扣--盛最多水的容器

题目链接:

https://leetcode.cn/problems/container-with-most-water/

一. 题目描述


二. 解题思路

两指针相向而行,只需遍历一遍数组就能找出最大容积,因此时间复杂度是O(N)。边遍历边更新最大值。

三. 代码实现

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

        while(left < right)
        {
            // 更新最大值
            int area = min(height[left], height[right])*(right - left);
            if(maxarea < area)  maxarea = area;
            // 移动指向的元素小的指针
            if(height[left] < height[right]) left++;
            else right--;
        }
        return maxarea;
    }
};
相关推荐
8Qi81 小时前
LeetCode 23. 合并 K 个升序链表 —— 小顶堆(PriorityQueue)
数据结构·算法·leetcode·链表·
QiLinkOS1 小时前
《打破“用爱发电”:一种基于 Gitee 与时间戳的开源权益分配机制探索》
c语言·数据结构·c++·科技·算法·gitee·开源
松间听晚2 小时前
Agentic RL 环境和代码学习:以HGPO为例
算法
智者知已应修善业2 小时前
【51单片机用T0定时器方式1,实现0.5S的时间间隔实现第一次一个灯亮、第二次二个灯亮,直到全部灯亮,然后重复整个过程】2023-12-29
c++·经验分享·笔记·算法·51单片机
小许同学记录成长2 小时前
几何体编辑与布尔运算
算法·无人机
fanged2 小时前
简单看看3A算法2(TODO)
算法
智者知已应修善业2 小时前
【51单片机4位静态数码管显示1234】2023-11-14
c++·经验分享·笔记·算法·51单片机
♡すぎ♡3 小时前
镜面 IBL 预过滤贴图的计算
算法·计算机图形学·贴图·pbr
Lsk_Smion3 小时前
力扣实训 _ [200].岛屿数量
算法·leetcode·深度优先
Boom_Shu3 小时前
长方形的关系
数据结构·c++·算法