LeetCode 盛最多水的容器 双指针

原题链接:

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题面:

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

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

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

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

示例 1:

复制代码
输入:[1,8,6,2,5,4,8,3,7]
输出:49 
解释:图中垂直线代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。

示例 2:

复制代码
输入:height = [1,1]
输出:1

提示:

  • n == height.length
  • 2 <= n <= 10^5
  • 0 <= height[i] <= 10^4

解题思路:

如果使用最朴素的做法,两层for循环分别枚举左端点和右端点,那么一定会超时,考虑使用双指针,达到O(n)的复杂度。

由于容纳的水量是由两个指针指向的数字中较小值∗指针之间的距离 决定的。如果我们移动数字较大的那个指针,那么前者「两个指针指向的数字中较小值」不会增加,后者「指针之间的距离」会减小,那么这个乘积会减小。因此,我们移动数字较大的那个指针是不合理的。因此,我们移动 数字较小的那个指针。 这是符合直觉的。

代码(CPP):

cpp 复制代码
class Solution {
public:
    int maxArea(vector<int>& height) {
        int n = height.size();
        int ans = 0;
        int l = 0, r = n - 1;
        while (l < r) {
            int area = (min(height[l], height[r])) * (r - l);
            ans = max(ans, area);
            if (height[l] > height[r]) {
                r--;
            } else {
                l++;
            }
        }
        return ans;
    }
};
相关推荐
无限进步_18 小时前
【C语言&数据结构】对称二叉树:镜像世界的递归探索
c语言·开发语言·数据结构·c++·git·算法·visual studio
星辞树18 小时前
揭秘阿里 DIN:当深度学习遇上“千物千面”
算法
刘立军18 小时前
如何选择FAISS的索引类型
人工智能·算法·架构
小芒果_0118 小时前
整理归并排序
c++·算法·排序算法·信息学奥赛
牛三金18 小时前
匿踪查询沿革-Private Information Retrieval(PIR)
算法·安全
德育处主任18 小时前
『NAS』在群晖部署一个文件加密工具-hat.sh
前端·算法·docker
星辞树18 小时前
从 L1/L2 到 Dropout:深度解析正则化,为何推荐系统“只能练一次”?
算法
玖剹18 小时前
队列+宽搜(bfs)
数据结构·c++·算法·leetcode·宽度优先
mit6.82419 小时前
01bfs|前缀和的前缀和
算法
wen__xvn19 小时前
代码随想录算法训练营DAY11第五章 栈与队列part02
算法