LeetCode 算法:盛最多水的容器c++

原题链接🔗盛最多水的容器
难度:中等⭐️⭐️

题目

给定一个长度为 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 <= 105

0 <= height[i] <= 104

题解

双指针

  1. 题解

LeetCode上的"盛最多水的容器"问题是一个典型的双指针问题,它要求你找到一个容器的形状,使得其盛水的体积最大。容器的形状由一个整数数组表示,其中每个元素代表容器在该位置的宽度。

这个问题可以通过以下逻辑来解决:

  • 初始化指针:设置两个指针 left 和 right,分别指向数组的开始和结束位置。

  • 计算面积 :在每一步中,计算两个指针之间的面积。面积可以通过 min(height[left], height[right]) * (right - left) 来计算,其中 min(height[left], height[right]) 是两个指针中较小的高度,(right - left) 是两个指针之间的宽度。

  • 更新最大面积:将当前面积与之前记录的最大面积进行比较,并更新最大面积。

  • 移动指针 :移动 left 或 right 指针以尝试找到更大的面积。选择移动哪个指针取决于 height[left] 和 height[right] 的值。如果 height[left] < height[right],则移动 left 指针,因为移动较短的边可以更快地尝试新的高度。反之,则移动 right 指针。

  • 循环结束条件:当 left 和 right 指针相遇时,循环结束。

  • 返回结果:返回记录的最大面积。

这个算法的关键在于理解,移动较短边的指针可以更快地探索新的高度,因为容器的面积由两个因素决定:宽度和高度。当宽度固定时,高度越小,面积越小。因此,通过移动较短边的指针,我们可以更快地找到可能的更大面积。

  1. 复杂度:时间复杂度O(N),空间复杂度O(1)。
  2. 代码过程:
  • 初始化两个指针 left 和 right 分别指向数组的开始和结束位置。
  • 在 while 循环中,计算当前面积 width *min(height[left], height[right]),其中 width 是两个指针之间的距离,min(height[left], height[right]) 是容器在当前指针位置的最小高度。
  • 更新 max_area 为当前面积和已知最大面积之间的较大值。
  • 移动较短边的指针,因为移动较长边的指针不会增加面积。
  • 当两个指针相遇时,循环结束。
  1. c++ demo:
cpp 复制代码
#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

int maxArea(vector<int>& height) {
    int max_area = 0;
    int left = 0;
    int right = height.size() - 1;

    while (left < right) {
        int width = right - left;
        int current_area = width * min(height[left], height[right]);
        max_area = max(max_area, current_area);

        if (height[left] < height[right]) {
            left++;
        }
        else {
            right--;
        }
    }

    return max_area;
}

int main() {
    // 示例输入
    vector<int> height1 = { 1,8,6,2,5,4,8,3,7 };
    vector<int> height2 = { 1,1,1 };

    // 调用 maxArea 函数并打印结果
    cout << "Maximum water that can be trapped with height1: " << maxArea(height1) << endl;
    cout << "Maximum water that can be trapped with height2: " << maxArea(height2) << endl;

    return 0;
}
  • 输出结果:

Maximum water that can be trapped with height1: 49

Maximum water that can be trapped with height2: 2

相关推荐
智者知已应修善业2 分钟前
【51单片机1,左边4个LED灯先闪烁2次后,右边4个LED灯再闪烁2次:2,接着所用灯一起闪烁3次,接着重复步骤1,如此循环。】2023-5-19
c++·经验分享·笔记·算法·51单片机
米啦啦.2 分钟前
红黑树,,
数据结构·红黑树
xiaoye-duck8 分钟前
《算法题讲解指南:优选算法-队列+宽搜》--70.N叉树的层序遍历,71.二叉树的锯齿形层序遍历,72.二叉树的最大宽度,73.在每个树行中找最大值
数据结构·c++·算法·队列
代码改善世界9 分钟前
【C++初阶】双向循环链表:List底层结构的完整实现剖析
c++·链表·list
汀、人工智能10 分钟前
[特殊字符] 第98课:数据流中位数
数据结构·算法·数据库架构··数据流·数据流中位数
REDcker12 分钟前
C++ 包管理工具概览
开发语言·c++
Eloudy13 分钟前
不同特征值的特征向量互相正交的矩阵
人工智能·算法·机器学习
人道领域15 分钟前
【LeetCode刷题日记】:从 LeetCode 经典题看哈希表的场景化应用---数组、HashSet、HashMap 选型与算法实战
算法·leetcode·面试
努力努力再努力wz16 分钟前
【C++高阶系列】告别内查找局限:基于磁盘 I/O 视角的 B 树深度剖析与 C++ 泛型实现!(附B树实现源码)
java·linux·开发语言·数据结构·c++·b树·算法
承渊政道17 分钟前
【优选算法】(实战攻坚BFS之FloodFill、最短路径问题、多源BFS以及解决拓扑排序)
数据结构·c++·笔记·学习·算法·leetcode·宽度优先