首页 > 其他 > 详细

leetcode 138:container-with-most-water

时间:2020-08-12 15:07:32      阅读:43      评论:0      收藏:0      [点我收藏+]

题目描述

给定n个非负整数a1,a2,…,an,其中每个数字表示坐标(i, ai)处的一个点。以(i,ai)和(i,0)(i=1,2,3...n)为端点画出n条直线。你可以从中选择两条线与x轴一起构成一个容器,最大的容器能装多少水?
注意:你不能倾斜容器
技术分享图片
例如:
输入 [1,8,6,2,5,4,8,3,7]
输出: 49
题目分析:
容器中水的容量等于容器左壁与右壁之间的距离与左壁右壁之间高度最小的值之间的乘积。这题最关键的是两点:一是两边往中间找,二是每次放弃最短的板。
代码如下:
1 int maxArea(vector<int>& height) {
2         int left,right,Max =-9999;
3         for(left = 0,right = height.size() - 1;left < right;)
4         {
5             Max = max(Max,(right - left)*min(height[left],height[right]));
6             height[left]<height[right]?left++:right--;
7         }
8         return Max;
9     }

 

leetcode 138:container-with-most-water

原文:https://www.cnblogs.com/qingjiaowoxiaoxioashou/p/13490241.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!