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. 面试时可用一句话总结思路:

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


相关推荐
兰令水9 分钟前
leecodecode【单调栈】【2026.6.12打卡-java版本】
java·开发语言·算法
dnbug Blog14 分钟前
C程序 基本语法
c语言·基本语法
TMT星球18 分钟前
魔法原子上交会首秀VLA K02大模型,完成具身智能从“执行”到“理解”的能力跃迁
人工智能·算法·机器学习
2301_7644413319 分钟前
番茄钟+AI:高效专注的秘密武器
人工智能·算法·数学建模·动态规划·交互
影寂ldy23 分钟前
C# 泛型委托
java·算法·c#
星马梦缘36 分钟前
算法设计与分析 作业三 纯答案
算法
吴阿福|一人公司38 分钟前
深度解析 Python 类变量修改的命名空间隔离
java·服务器·数据结构
不知名的老吴1 小时前
经典算法题之行星碰撞
数据结构·算法
AI科技星1 小时前
数术工坊・八卷全书(番外・实战升华副卷)【终极典藏定稿|完整无删减】
c语言·开发语言·网络·量子计算·agi
丘山望岳1 小时前
剑起霜华——平衡二叉树(AVL树 )精讲
开发语言·数据结构·c++