LeetCode 11:盛最多水的容器(C语言实现)

题目描述

给定一个长度为 n 的整数数组 height。有 n 条垂线,第 i 条线的两个端点是 (i, 0)(i, height[i])。请你找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。返回容器可以储存的最大水量。

注意: 你不能倾斜容器。

示例

示例 1:

复制代码
输入:height = [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


解题思路

  1. 容器面积公式

area = \\min(height\[left\], height\[right\]) \\times (right - left)

  1. 双指针策略
  • 初始化左右指针:

    复制代码
    left = 0;
    right = heightSize - 1;
  • 每次计算面积,并更新最大值

  • 移动较短的那一边指针,因为移动长边只会让宽度减小,面积不会增加。

  1. 时间复杂度 :O(n)
    空间复杂度:O(1)

C语言代码实现

复制代码
#include <stdio.h>

int maxArea(int* height, int heightSize) {
    int left = 0;
    int right = heightSize - 1;
    int max = 0;

    while (left < right) {
        int h = height[left] < height[right] ? height[left] : height[right];
        int area = h * (right - left);

        if (area > max)
            max = area;

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

    return max;
}

// 测试
int main() {
    int height[] = {1,8,6,2,5,4,8,3,7};
    int size = sizeof(height)/sizeof(height[0]);
    printf("最大水量 = %d\n", maxArea(height, size));
    return 0;
}

示例解析

对于输入 [1,8,6,2,5,4,8,3,7]

  • 初始左右指针:left=0 (1)right=8 (7)

  • 面积 = min(1,7)*(8-0)=8 → 移动左指针

  • 继续计算,每次移动较短边

  • 最终最大面积为 49left=1 (8)right=8 (7)


面试小贴士

  1. 这题属于 双指针技巧题,重点是"移动短板"的策略。

  2. 面试时可用一句话总结思路:

    左右双指针夹逼,每次计算面积并移动较短边,因为移动长边只会缩小宽度而不会增加高度。


相关推荐
田梓燊3 分钟前
leetcode 56
java·算法·leetcode
仍然.26 分钟前
多线程---阻塞队列收尾和线程池
java·开发语言·算法
_深海凉_26 分钟前
LeetCode热题100-最长公共前缀
算法·leetcode·职场和发展
郝学胜-神的一滴26 分钟前
PyTorch自动微分核心解析:从原理到实战实现权重更新
人工智能·pytorch·python·深度学习·算法·机器学习
会编程的土豆1 小时前
【数据结构与算法】 拓扑排序
数据结构·c++·算法
zth4130211 小时前
SegmentSplay‘s Super STL(v2.2)
开发语言·c++·算法
数据知道1 小时前
claw-code 源码详细分析:Bootstrap Graph——启动阶段图式化之后,排障与扩展为什么会变简单?
前端·算法·ai·bootstrap·claude code·claw code
Kel1 小时前
从Prompt到Response:大模型推理端到端核心链路深度拆解
人工智能·算法·架构
Felven1 小时前
D. Matryoshkas
算法
17(无规则自律)1 小时前
DFS连通域统计:岛屿数量问题及其变形
c++·算法·深度优先