leetcode-[数组、双指针-对撞指针] - 乘最多水的容器(11)

使用双指针策略解决LeetCode第11题,找到数组中两个元素形成的最大矩形面积。通过不断移动指针,调整较小高度的元素位置,以最大化与x轴围成的矩形面积。算法的时间复杂度为O(n),空间复杂度为O(1)。
摘要由CSDN通过智能技术生成

1、问题描述

给定一个有n个非负整数的数组,以数组的索引作为x坐标,对应索引的元素值作为y坐标,找到两个坐标(x1,y1)和(x2,y2),使得他们与x轴围成的矩形面积最大。
如下图所示,图中垂直线的高度代表输入数组 [1,8,6,2,5,4,8,3,7]。在此情况下,容器能够容纳水(表示为蓝色部分)的最大值为 49。
在这里插入图片描述

2、解题思路

  • 边界条件:(1)数组的元素个数小于等于2;
  • 问题分析:这道题和two-sum问题很像,two-sum问题是要求找到数组和等于某个值的两个数,而这道题是要求找到两个坐标(索引及其对应的元素值),使得它们与x轴围成的面积最大。所以可以采用双指针来解决。在给出具体的双指针移动规则前,我们先来看一下怎么移动才有可能使得面积增大。
  • 假设由 h [ i ] h[i] h[i] h [ j ] h[j] h[j]以及 x x x轴围成的矩形面积为 S ( i , j ) S(i,j) S(i,j)
  • S ( i , j ) = m i n ( h [ i ] , h [ j ] ) ∗ ( j − i ) S(i,j)=min(h[i],h[j]) *(j-i) S(i,j)=min(h[i],h[j])(ji);
  • 无论是 i i i还是 j j j往中间移动时, ( j − i ) (j-i) (ji)都在变小,
  • 假设 m i n ( h [ i ] , h [ j ] ) = h [ i ] min(h[i],h[j])=h[i] min(h[i],h[j])=h[i],即两者中最小的为 h [ i ] h[i]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Albert_YuHan

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值