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记录最大值;

相关推荐
Jack204 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树5 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE21221 小时前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE21221 小时前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫1 天前
Electron 系列文章封面图
算法·架构·前端框架
徐小夕1 天前
JitWord 3.0 正式发布,高精度Word异构解析+复杂组件兼容,打造web端协同Word编辑器
前端·vue.js·算法