LeetCodeHot100——盛水最多的容器

题目链接放在这里了:

11. 盛最多水的容器 - 力扣(LeetCode)

这道题实际做起来非常的简单,只需要想明白一件事就好了,怎么移动双指针:具体的做法如下:

java 复制代码
class Solution {
    public int maxArea(int[] height) {
        if(height==null||height.length==0){
            return 0;
        }
        int l = 0;
        int r = height.length-1;
        int res = 0;
        while(l<r){
            int curArea = (r-l)*Math.min(height[l],height[r]);
            res = Math.max(curArea,res);
            if(height[l]<height[r]){
                l++;
            }else{
                r--;
            }
        }
        return res;
    }
}

这题的目的是找出两个柱子间最大的面积,即下标的差*两个柱子之中较矮的高度的最大值,这道题我只想出了暴力做法就是进行两个for循环,时间复杂度超出要求了;

这道题正确的做法是先分析题意,如果说任取两个柱子计算面积值,如果较矮的柱子和中间的柱子组成容器的话,如果说那个柱子比较矮的柱子还要矮那么下标差和两个柱子之中较矮的高度都会变小,所以面积不可能比原来的大,如果说那个柱子比较矮的柱子高,那么两个柱子之中较矮的高度不变,下标差变小所以也不会比原来的面积大。所以说保持较矮的柱子不变改变另一个柱子是不可行的其面积必然比原值小,想要找到比原来面积更大的面积的话,我们需要改变较矮的柱子,所以我们的思路就是创建对向指针,一个指向最后一个元素,一个指向首元素,进行遍历,条件是左指针小于右指针,取其中较小的元素进行移动,左指针右移,右指针左移,并设置max记录最大值;

相关推荐
3DVisionary1 小时前
蓝光三维扫描:磁性轴承全尺寸精密3D检测方案
算法·3d·3d检测·蓝光三维扫描·精密检测·磁性轴承·圆度测量
过期动态1 小时前
【LeetCode 热题 100】三数之和
java·数据结构·算法·leetcode·职场和发展·排序算法
逻辑君1 小时前
Foresight研究报告【20260010】
人工智能·算法·机器学习
一切皆是因缘际会2 小时前
AI高速迭代下的技术风险与理性突围
大数据·数据结构·人工智能·架构
weixin_468466852 小时前
大语言模型原理新手入门指南
人工智能·python·算法·语言模型·自然语言处理·transformer·注意力机制
z200509302 小时前
今日算法(回溯找IP,加检测)
算法·leetcode
sheeta19982 小时前
LeetCode 补拙笔记 日期:2026.05.29 题目:1559. 二维网格图中探测环
笔记·算法·leetcode
罗超驿2 小时前
10.滑动窗口解决:无重复字符的最长子串 | LeetCode 3 Java 题解
java·算法·leetcode·面试
罗超驿2 小时前
8.【LeetCode 18】四数之和 —— Java 排序 + 双指针解法详解
算法·leetcode·职场和发展