盛水最多的容器

hello 大家好!今天开写一个新章节,每一天一道算法题。让我们一起来学习算法思维吧!

javascript 复制代码
function maxArea(height) {
    // 初始化最大水量为 0
    let maxWater = 0;
    // 初始化左指针,指向数组的第一个元素
    let left = 0;
    // 初始化右指针,指向数组的最后一个元素
    let right = height.length - 1;

    // 只要左指针小于右指针,就继续循环
    while (left < right) {
        // 计算当前左右指针所指垂线构成的容器的宽度
        const width = right - left;
        // 计算当前左右指针所指垂线构成的容器的高度,取两者中的较小值
        const currentHeight = Math.min(height[left], height[right]);
        // 计算当前容器能容纳的水量
        const currentWater = width * currentHeight;
        // 更新最大水量
        maxWater = Math.max(maxWater, currentWater);

        // 如果左指针所指垂线的高度小于右指针所指垂线的高度
        if (height[left] < height[right]) {
            // 左指针右移一位
            left++;
        } else {
            // 否则,右指针左移一位
            right--;
        }
    }

    // 返回最大水量
    return maxWater;
}

// 测试示例
const height = [1, 8, 6, 2, 5, 4, 8, 3, 7];
console.log(maxArea(height)); 

代码解释

整体思路

本题使用双指针法来解决。我们使用两个指针分别指向数组的开头和结尾,通过计算这两个指针所指垂线与 x 轴构成的容器的水量,并不断移动指针来寻找最大水量。由于容器的水量由宽度(两个指针的距离)和高度(两个指针所指垂线高度的较小值)决定,每次移动较短的垂线对应的指针,这样有可能找到更大的水量。

代码步骤分析

初始化变量:

  • maxWater:用于记录最大水量,初始化为 0。
  • left:左指针,初始指向数组的第一个元素,索引为 0。
  • right:右指针,初始指向数组的最后一个元素,索引为 height.length - 1。

双指针遍历:

  • 使用 while 循环,只要 left 小于 right 就继续循环。
  • 在每次循环中,计算当前容器的宽度 width 为 right - left。
  • 计算当前容器的高度 currentHeight 为 height[left] 和 height[right] 中的较小值。
  • 计算当前容器能容纳的水量 currentWater 为 width * currentHeight。
  • 更新 maxWater 为 maxWater 和 currentWater 中的较大值。 根据 height[left] 和
    height[right] 的大小关系移动指针:如果 height[left] 小于 height[right],将 left
    指针右移一位;否则,将 right 指针左移一位。

返回结果:

  • 当 left 不再小于 right 时,循环结束,返回 maxWater,即最大水量。
相关推荐
韩立学长1 分钟前
【开题答辩实录分享】以《基于Python的大学超市仓储信息管理系统的设计与实现》为例进行选题答辩实录分享
开发语言·python
风筝在晴天搁浅4 分钟前
hot100 78.子集
java·算法
Jasmine_llq7 分钟前
《P4587 [FJOI2016] 神秘数》
算法·倍增思想·稀疏表(st 表)·前缀和数组(解决静态区间和查询·st表核心实现高效预处理和查询·预处理优化(提前计算所需信息·快速io提升大规模数据读写效率
超级大只老咪21 分钟前
快速进制转换
笔记·算法
东东51621 分钟前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
froginwe1125 分钟前
Scala 循环
开发语言
catino25 分钟前
图片、文件的预览
前端·javascript
m0_7066532343 分钟前
C++编译期数组操作
开发语言·c++·算法
故事和你911 小时前
sdut-Java面向对象-06 继承和多态、抽象类和接口(函数题:10-18题)
java·开发语言·算法·面向对象·基础语法·继承和多态·抽象类和接口
Bruk.Liu1 小时前
(LangChain实战2):LangChain消息(message)的使用
开发语言·langchain