(C++)盛水最多的容器--双指针法

个人主页:Lei宝啊

愿所有美好如期而遇


力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台备战技术面试?力扣提供海量技术面试资源,帮助你高效提升编程技能,轻松拿下世界 IT 名企 Dream Offer。https://leetcode.cn/problems/container-with-most-water/

算法原理

双指针法,不一定是说就要使用指针,只是一种形象的说法,在数组中,我们一般将数组下标当做指针。这道题目中,我们定义left以及right,left赋值0,right赋值size-1,我们图示分析这道题目:

图示

代码

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

        int maxV = 0;
        while(right != left)
        {
            int h = height[right] > height[left] ? height[left] : height[right];
            int w = right - left;

            int V = h * w;
            if(V > maxV)
                maxV = V;

            if(height[right] >= height[left])
            {
                left++;
            }
            else
            {
                right--;
            }
        }

        return maxV;
    }
};
相关推荐
老鼠只爱大米1 分钟前
LeetCode算法题详解 42:接雨水
leetcode·动态规划·双指针·单调栈·接雨水·雨水收集
3GPP仿真实验室7 分钟前
【Python源码】6G:PyTorch OFDM 教学仿真平台
算法
xie_pin_an10 分钟前
C++ 从入门到进阶:核心知识与实战指南
java·c++·算法
No0d1es14 分钟前
2025年12月 GESP CCF编程能力等级认证C++八级真题
开发语言·c++·青少年编程·gesp·ccf
我是个菜鸡.24 分钟前
多模态算法面经准备
算法
AlenTech25 分钟前
739. 每日温度 - 力扣(LeetCode)
算法·leetcode·职场和发展
fqbqrr35 分钟前
2601C++,概念与约束及推导本
c++
xiaowu0801 小时前
C#调用 C++ DLL 加载地址方式选择
开发语言·c++·c#
老鼠只爱大米1 小时前
LeetCode算法题详解 11:盛最多水的容器
leetcode·面试题·双指针·盛最多水的容器·面积最大化
转基因1 小时前
C++的IO流
开发语言·c++