算法每日一题 Day05|双指针解决盛最多水的容器问题

盛最多水的容器(附链接)

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

一、题目描述


二、思路

  • 核心思想是什么?
    利用双指针来进行计算
  • 为什么这么做?
    暴力解法的时间复杂度为O(n^2),时间超时,通过规律,单调性,体积V= 高度h宽度w

    按照示例:数组为 int[] height = {1,8,6,2,5,4,8,3,7};
    第一次计算:v = 1
    (8-0) = 8;
    第二次计算:v= 1*(7-0) = 7;
    第三次计算:v= 1*(6-0) = 6;
    通过以上计算,发现向内枚举的时候,高度不变,宽度在变小,整体的体积也是在减少,所以在高度不变的时候,宽度最大的,体积最大。
    所以我们想到利用双指针来解决这道题,定义两个指针,left指针指向数组的第一个数,right指针指向数组的最后一个数,第一次计算出体积v,然后移动指针(比较height[left] 和 height[right]中的值,如果left指向的值更小,left++,如果right指向的值更小,right--)

三、关键点

  • 能找到单调性来做这道题

四、代码(Java )

java 复制代码
class Solution {
    public int maxArea(int[] height) {
        int left = 0;
        int right = height.length - 1;
        int ret = 0;
        while (left < right) {
            //先计算出第一次的体积
            int v = Math.min(height[left], height[right]) * (right - left);
            //更新体积的最大值
            ret = Math.max(v, ret);
            if (height[left] < height[right])
                left++;
            else
                right--;
        }
        return ret;
    }

}

五、总结

面积 = 高度(两指针中较小值)× 宽度(指针间距)。

若移动较长的指针,高度不会增加(因为高度由短板决定),宽度减少,面积必然减小 → 浪费计算。

因此每次都移动较短的指针,才有可能让高度变大,从而在宽度减少的情况下依然获得更大面积。

相关推荐
小O的算法实验室28 分钟前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
chao1898447 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙7 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰8 小时前
倍增算法和ST表
算法
知识领航员8 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪9 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声10 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠10 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan10 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算