[LeetCode]11. 盛最多水的容器(双指针)
2024-09-07 19:58:38
题目
给定 n 个非负整数 a1,a2,...,an,每个数代表坐标中的一个点 (i, ai) 。在坐标内画 n 条垂直线,垂直线 i 的两个端点分别为 (i, ai) 和 (i, 0)。找出其中的两条线,使得它们与 x 轴共同构成的容器可以容纳最多的水。
题解
双指针,每次将矮的那边往里移(因为面积的高=矮的高度,长度现在又是最长的,所以此时面积为矮的做边界的最大值),并维护最大面积。
代码
class Solution {
public int maxArea(int[] height) {
if(height==null||height.length<2){
return 0;
}
int maxArea=0;
int l=0;
int r=height.length-1;
while(l<r){
int area=Math.min(height[l],height[r])*(r-l);
maxArea=area>maxArea?area:maxArea;
if(height[l]<height[r]){
++l;
}
else{
--r;
}
}
return maxArea;
}
}
最新文章
- python 异常处理学习笔记
- 1211php面向对象
- Box2D淌坑日记: 如何正确的设置角度
- JavaScript Number 对象 Javascript Array对象 Location 对象方法 String对象方法
- TextView里的文 html
- 实现Win7远程桌面关机和重启
- HTML笔记1
- Codeforces Gym 100342E Problem E. Minima 暴力
- 使用cocos2d 2.1制作一条河游戏(4): 主要的游戏逻辑BaseLayer设计
- Charles使用(一)
- poj 2425 AChessGame(博弈)
- Java EE 开发环境搭建
- 导入tensorflow时DLL load failed: 找不到指定的模块
- Arduino SD卡 列出文件
- Java中加密算法介绍及其实现
- finecms5采集接口下载
- Grunt教程——安装Grunt
- Java 微服务实践 - Spring Boot 系列
- IRGAN:A Minimax Game for Unifying Generative and Discriminative Information Retrieval Models
- C# GDI+开发手记