Leetcode11. 盛最多水的容器

Every day a Leetcode

题目来源:11. 盛最多水的容器

解法1:暴力

代码:

c 复制代码
class Solution
{
public:
    int maxArea(vector<int> &height)
    {
        int max_area = INT_MIN;
        for (int i = 0; i < height.size() - 1; i++)
            for (int j = i + 1; j < height.size(); j++)
                max_area = max(max_area, min(height[i], height[j]) * (j - i));
        return max_area;
    }
};

结果:超时

复杂度分析:

时间复杂度:O(n2),其中 n 是数组 height的元素个数。

空间复杂度:O(1)。

解法2:双指针

在初始时,左右指针分别指向数组的左右两端。

此时我们需要移动一个指针。移动哪一个呢?直觉告诉我们,应该移动对应数字较小的那个指针。

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

答案就是我们每次以双指针为左右边界(也就是「数组」的左右边界)计算出的容量中的最大值。

代码:

c 复制代码
// 双指针

class Solution
{
public:
    int maxArea(vector<int> &height)
    {
        int left = 0, right = height.size() - 1;
        int max_area = INT_MIN;
        while (left < right)
        {
            int area = min(height[left], height[right]) * (right - left);
            max_area = max(max_area, area);
            if (height[left] < height[right])
                left++;
            else
                right--;
        }
        return max_area;
    }
};

结果:

复杂度分析:

时间复杂度:O(n),其中 n 是数组 height的元素个数。

空间复杂度:O(1)。

相关推荐
再睡一夏就好18 分钟前
【C++闯关笔记】unordered_map与unordered_set的底层:哈希表(哈希桶)
开发语言·c++·笔记·学习·哈希算法·散列表
mjhcsp19 分钟前
C++ 贪心算法(Greedy Algorithm)详解:从思想到实战
c++·ios·贪心算法
potato_155424 分钟前
现代C++核心特性——内存篇
开发语言·c++·学习
沐怡旸1 小时前
【穿越Effective C++】条款13:以对象管理资源——RAII原则的基石
c++·面试
一个不知名程序员www1 小时前
算法学习入门---二分查找(C++)
c++·算法
2301_807997382 小时前
代码随想录-day26
数据结构·c++·算法·leetcode
闭着眼睛学算法2 小时前
【双机位A卷】华为OD笔试之【排序】双机位A-银行插队【Py/Java/C++/C/JS/Go六种语言】【欧弟算法】全网注释最详细分类最全的华子OD真题题解
java·c语言·javascript·c++·python·算法·华为od
小欣加油2 小时前
leetcode 3318 计算子数组的x-sum I
c++·算法·leetcode·职场和发展
j_xxx404_3 小时前
C++ STL:list|了解list|相关接口|相关操作
开发语言·c++
kyle~3 小时前
机器视觉---Intel RealSense SDK 2.0 开发流程
运维·c++·windows·深度相机·intel realsense