题目

给定 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;
}
}

最新文章

  1. python 异常处理学习笔记
  2. 1211php面向对象
  3. Box2D淌坑日记: 如何正确的设置角度
  4. JavaScript Number 对象 Javascript Array对象 Location 对象方法 String对象方法
  5. TextView里的文 html
  6. 实现Win7远程桌面关机和重启
  7. HTML笔记1
  8. Codeforces Gym 100342E Problem E. Minima 暴力
  9. 使用cocos2d 2.1制作一条河游戏(4): 主要的游戏逻辑BaseLayer设计
  10. Charles使用(一)
  11. poj 2425 AChessGame(博弈)
  12. Java EE 开发环境搭建
  13. 导入tensorflow时DLL load failed: 找不到指定的模块
  14. Arduino SD卡 列出文件
  15. Java中加密算法介绍及其实现
  16. finecms5采集接口下载
  17. Grunt教程——安装Grunt
  18. Java 微服务实践 - Spring Boot 系列
  19. IRGAN:A Minimax Game for Unifying Generative and Discriminative Information Retrieval Models
  20. C# GDI+开发手记

热门文章

  1. Mybatis-05-使用注解开发
  2. Atomic原子类
  3. springMVC入门(七)------RESTFul风格的支持
  4. 解决使用git,ssh每次都要输入密码
  5. 在服务器上使用python-gym出现的关于显示的问题
  6. NumPy笔记-ndarray
  7. JavaFX桌面应用-SpringBoot + JavaFX
  8. 「从零单排canal 07」 parser模块源码解析
  9. Nuxt.js 踩坑记录(3) Net.connection xxxx
  10. xmind8 破解激活教程