LeetCode 11 - 盛最多水的容器 - [双指针暴力]
题目链接:https://leetcode-cn.com/problems/container-with-most-water/description/
给定 n 个非负整数 $a_1,a_2,\cdots,a_{n-1},a_n$,每个数代表坐标中的一个点 $(i, a_i)$。在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 $(i, ai_)$ 和 $(i, 0)$。
找出其中的两条线,使得它们与 $x$ 轴共同构成的容器可以容纳最多的水。
说明:你不能倾斜容器,且 $n$ 的值至少为 2。
示例:
输入: [1,8,6,2,5,4,8,3,7]
输出: 49
(引用来自官网上的)题解:
这种方法背后的思路在于,两线段之间形成的区域总是会受到其中较短那条长度的限制。此外,两线段距离越远,得到的面积就越大;
我们在由线段长度构成的数组中使用两个指针,一个放在开始,一个置于末尾;
此外,我们会使用变量 maxarea 来持续存储到目前为止所获得的最大面积;
在每一步中,我们会找出指针所指向的两条线段形成的区域,更新 maxarea,并将指向较短线段的指针向较长线段那端移动一步。
说实话,其实算法过程非常简单,实现起来也就个位数行的代码,但是,怎么证明这样的算法是正确的呢?
证明(以下参考https://segmentfault.com/a/1190000016654619):
假设最优解的容器的两个边界在位置 $L$ 和 $R$,高度为 $h(L)$ 和 $h(R)$,那么根据算法,由于每次左右指针中只有一个能移动一步,那么必然有一个先到达两个边界中的一个,
不妨假设是左指针先走到 $L$,即 $l=L$;那么此时右指针必然还没有走到 $R$,即 $r > R$;
那么,只要证明如下假设:接下来的每一步都只能是右指针左移一格,左指针始终不能动。就意味着我们的算法在枚举过程中,必然会在某一步走到最优解,从而使得算法得到的答案正确;
采用反证法:
若上述假设不成立,则意味着如下假设成立:必然存在某一步,是左指针右移一格,而右指针没有动;
则根据以上描述可知,在这一步的时候:$l=L<R<r$ 且 $h(l) = h(L) < h(r)$,由此可知此时边界为 $l$ 和 $r$ 的容器的容量 $S$ 为
$S = h\left( l \right) \times \left( {r - l} \right) = h\left( L \right) \times \left( {r - l} \right)$
然而,此时我们根据 $r > R \Rightarrow r - l > R - l = R - L$ 又有
$S = h\left( L \right) \times \left( {r - l} \right) > \min \left( {h\left( L \right),h\left( R \right)} \right) \times \left( {R - L} \right)$
很明显,$\min \left( {h\left( L \right),h\left( R \right)} \right) \times \left( {R - L} \right)$ 已经是最大的容积了,显然不应当存在不这还大的容器,
因此,证明了假设:当左指针先走到 $L$ 时,接下来的每一步都只能是右指针左移一格,左指针始终不能动;
类似地,也可以证明,当右指针先走到 $R$ 时,接下来的每一步都只能是左指针右移一格,右指针始终不能动;
证毕。
AC代码:
class Solution
{
public:
int maxArea(vector<int>& height)
{
int mx=,l=,r=height.size()-;
while(l<r)
{
mx=max(mx,min(height[l],height[r])*(r-l));
if(height[l]<height[r]) l++;
else r--;
}
return mx;
}
};
LeetCode 11 - 盛最多水的容器 - [双指针暴力]的更多相关文章
- Java实现 LeetCode 11 盛最多水的容器
11. 盛最多水的容器 给定 n 个非负整数 a1,a2,-,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0) ...
- 力扣Leetcode 11. 盛最多水的容器
盛最多水的容器 给你 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找 ...
- [LeetCode]11. 盛最多水的容器(双指针)
题目 给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找出其中的两 ...
- Leetcode 11.盛最多水的容器 By Python
给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找出其中的两条线, ...
- LeetCode 11. 盛最多水的容器(Container With Most Water)
题目描述 给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .画 n 条垂直线,使得垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找出其中的两 ...
- LeetCode:盛最多水的容器【11】
LeetCode:盛最多水的容器[11] 题目描述 给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 ...
- 【LeetCode】盛最多水的容器【双指针+贪心 寻找最大面积】
给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找出其中的两条线, ...
- Leetcode题库——11.盛最多水的容器
@author: ZZQ @software: PyCharm @file: maxArea.py @time: 2018/10/11 21:47 说明:给定 n 个非负整数 a1,a2,...,an ...
- 【LeetCode】11. 盛最多水的容器
题目 给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) .在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0).找出其中的两 ...
随机推荐
- 12C -- ORA-65048 ORA-65048
创建common user的时候报错: $ sqlplus '/as sysdba' SQL*Plus: Release 12.2.0.1.0 Production on Tue Apr 18 11: ...
- Docker 使用Docker知识简易部署一个LNMP平台
1.自定义网络 docker network create lnmp 2.创建Mysql数据库容器(这里我们首先得创建一个mysql-vol数据卷) docker volume create mysq ...
- 严苛模式 strictmode
参考链接 http://blog.csdn.net/brokge/article/details/8543145 一.严苛模式-虚拟机策略 虚拟机策略(VmPolicy)能检查内存泄漏,譬如,当关闭一 ...
- 原生AJAX请求教程
ajax 即 Asynchronous Javascript And XML,AJAX 不是一门的新的语言,而是对现有持术的综合利用.本质是在 HTTP 协议的基础上以异步的方式与服务器进行通信. 异 ...
- 基于Extjs 4.2的通用权限管理系统,通用后台模板,EF+MVC+Extjs 4.2
基于Extjs 4.2的通用权限管理系统,通用后台. 我们的宗旨:珍爱生命,拒绝重复!Don't Repeat Yourself!!! 本案例采用EntityFramework+MVC4.0+Extj ...
- AllPay(欧付宝)支付接口集成
AllPay,http://www.allpay.com.tw/,欧付宝是台湾知名的第三方支付公司,拥有丰富的支付模式(支持和支付宝.财付通),只需要一次对接,各种支付模式均可使用. 接口编写SDK: ...
- chrome调试手机webview中页面
http://blog.csdn.net/freshlover/article/details/42528643 注: 1. 可以调试真机上页面(USB连接)和虚拟机上页面 2. 手机系统需要4.4+ ...
- Java8学习笔记(四)--接口增强
增强点 静态方法 public interface InterfacePlus { void run(); static Date createDate(){ return new Date(); } ...
- tensorflow随机梯度下降算法使用滑动平均模型
在采用随机梯度下降算法训练神经网络时,使用滑动平均模型可以提高最终模型在测试集数据上的表现.在Tensflow中提供了tf.train.ExponentialMovingAverage来实现滑动平均模 ...
- irc
https://www.irccloud.com/ webchat.freenode.net http://blog.csdn.net/wcc526/article/details/16993069 ...