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

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


相关推荐
田梓燊18 小时前
力扣:23.合并 K 个升序链表
算法·leetcode·链表
re林檎18 小时前
算法札记——4.27
算法
AI人工智能+电脑小能手19 小时前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
数据牧羊人的成长笔记19 小时前
逻辑回归与Softmax回归
算法·回归·逻辑回归
郑州光合科技余经理19 小时前
同城O2O海外版二次开发实战:从支付网关到配送算法
开发语言·前端·后端·算法·架构·uni-app·php
上弦月-编程21 小时前
递归实现C语言菱形图案打印
c语言
Mrlxl.cn21 小时前
计算机网络——网络层
c语言·数据结构·计算机网络·考研
d111111111d1 天前
STM32-UART封装问题解析
笔记·stm32·单片机·嵌入式硬件·学习·算法
寒秋花开曾相惜1 天前
(学习笔记)4.2 逻辑设计和硬件控制语言HCL(4.2.1 逻辑门&4.2.2 组合电路和HCL布尔表达式)
linux·网络·数据结构·笔记·学习·fpga开发
叶子野格1 天前
《C语言学习:指针》12
c语言·开发语言·c++·学习·visual studio