盛最多水的容器(双指针)

在这里插入图片描述

解题思路:
1,暴力解法(超时)

我们可以使用两层for循环进行遍历。找到那个最大的面积即可,这里我就不写代码了,因为写了也是超时。

2,双指针法

先定义两个指针一个在最左端,一个在最右端:矩形的体积是 底*高 ,我们将两个指针之间的距离当做底,当两个指针移动时底一定会减小,所以如果此时高还在减小,那么他的面积肯定会减小,所以我们就找高增大的作为矩形的两边,因此就有了height[left] > height[right] 这个判断条件,每次移动后都要比较,并取最大的体积,然后重复循环即可。此算法的时间复杂度是O(n)。

代码实现
class Solution {
    public int maxArea(int[] height) {
        int left = 0,right = height.length - 1;
        int ret =0;
        while(left < right){
            int v = (right - left) * Math.min(height[left],height[right]);
            if(height[left] > height[right]){
                right--;
            }else {
                left++;
            }
            if( ret < v){
                ret = v;
            }
        }
        return ret;
    }
}

相关推荐

最近更新

  1. TCP协议是安全的吗?

    2024-05-14 03:50:11       18 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2024-05-14 03:50:11       19 阅读
  3. 【Python教程】压缩PDF文件大小

    2024-05-14 03:50:11       18 阅读
  4. 通过文章id递归查询所有评论(xml)

    2024-05-14 03:50:11       20 阅读

热门阅读

  1. c++ string容器

    2024-05-14 03:50:11       11 阅读
  2. pat乙1033-旧键盘打字

    2024-05-14 03:50:11       14 阅读
  3. K折交叉验证

    2024-05-14 03:50:11       14 阅读
  4. C++Primer Plus第五章结构编程练习8

    2024-05-14 03:50:11       10 阅读
  5. git开发工作流程

    2024-05-14 03:50:11       13 阅读
  6. Rust :给数据类型起一个别名

    2024-05-14 03:50:11       12 阅读
  7. 数据结构(七)复杂度渐进表示

    2024-05-14 03:50:11       9 阅读
  8. 网络接口类型

    2024-05-14 03:50:11       11 阅读
  9. -general textual search application

    2024-05-14 03:50:11       10 阅读
  10. 布隆过滤器的原理简介

    2024-05-14 03:50:11       15 阅读
  11. Go语言中context原理及使用

    2024-05-14 03:50:11       11 阅读