力扣hot100 —— 11.盛最多的水

题目描述:

给定一个长度为 n 的整数数组 height 。有 n 条垂线,第 i 条线的两个端点是 (i, 0)(i, height[i])

找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。

返回容器可以储存的最大水量。

**说明:**你不能倾斜容器。

解法思路:

// 木桶效应,短板决定水的上限,抽象问题一下,其实就是找出一对数字,俩者距离*较小数 的值就是他们的水量

// 采用双指针,俩端开始,逐渐计算水量进行比较;

// 每次指针移动都是较小数字进行移动(木桶效应)

代码:

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        // 木桶效应,短板决定水的上限,抽象问题一下,其实就是找出一对数字,俩者距离*较小数的值就是他们的水量
        // 采用双指针,俩端开始,逐渐计算水量进行比较;
        // 每次指针移动都是较小数字进行移动(木桶效应)
        int left = 0;
        int right = height.size() - 1;  // 注意 索引是从0 开始的,右指针初始化是要减1的
        int result = 0; // 水量结果
        int temp_result = 0;
        while(left < right){
            if(height[left]>=height[right]){  // 左边比右边大,以右边为基础计算
                temp_result = height[right] * (right - left);
                --right; // 右指针移动
            }else{
                temp_result = height[left] * (right - left);
                ++left; // 右指针移动
            }
            result = max(result,temp_result);
        }
        return result;


    }
};
相关推荐
查理零世36 分钟前
【蓝桥杯集训·每日一题2025】 AcWing 6134. 哞叫时间II python
python·算法·蓝桥杯
仟濹36 分钟前
【二分搜索 C/C++】洛谷 P1873 EKO / 砍树
c语言·c++·算法
紫雾凌寒1 小时前
解锁机器学习核心算法|神经网络:AI 领域的 “超级引擎”
人工智能·python·神经网络·算法·机器学习·卷积神经网络
京东零售技术1 小时前
AI Agent实战:打造京东广告主的超级助手 | 京东零售技术实践
算法
且听风吟ayan2 小时前
leetcode day19 844+977
leetcode·c#
MiyamiKK572 小时前
leetcode_位运算 190.颠倒二进制位
python·算法·leetcode
C137的本贾尼2 小时前
解决 LeetCode 串联所有单词的子串问题
算法·leetcode·c#
青橘MATLAB学习3 小时前
时间序列预测实战:指数平滑法详解与MATLAB实现
人工智能·算法·机器学习·matlab
lingllllove3 小时前
matlab二维艾里光束,阵列艾里光束,可改变光束直径以及距离
开发语言·算法·matlab
88号技师3 小时前
2025年2月一区SCI-海市蜃楼搜索优化算法Mirage search optimization-附Matlab免费代码
开发语言·人工智能·算法·机器学习·matlab·优化算法