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

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


相关推荐
Emilin Amy2 小时前
一台具备了“观察力”的下肢康复外骨骼机器人
算法·机器人
I_LPL2 小时前
day53 代码随想录算法训练营 图论专题7
算法·图论
_日拱一卒2 小时前
LeetCode(力扣):二叉树的后序遍历
算法·leetcode·职场和发展
Emilin Amy2 小时前
【ROS】机器人的速度/角度/力矩控制是如何实现的
c++·算法·控制·ros1/2
sali-tec2 小时前
C# 基于OpenCv的视觉工作流-章36-骨架提取
图像处理·人工智能·opencv·算法·计算机视觉
CoovallyAIHub2 小时前
RF-DETR:最近一个月迭代 5 个版本的实时检测+分割模型
深度学习·算法·计算机视觉
Frostnova丶2 小时前
LeetCode 1878. 矩阵中最大的三个菱形和
算法·leetcode·矩阵
m0_662577972 小时前
C++中的享元模式实战
开发语言·c++·算法
集芯微电科技有限公司2 小时前
PC5204集成700V/7.5A 400mΩ增强型氮化镓GaN HEMT驱动器具有高功率密度运行
数据结构·人工智能·单片机·嵌入式硬件·神经网络·机器学习·生成对抗网络