LeetCode第11题盛最多水的容器

简介: 该文章介绍了 LeetCode 第 11 题盛最多水的容器的解法,通过分析得出只能移动短板才可能使面积变大的规律,使用双指针法解决该问题,避免了穷举法的高时间复杂度,并总结了算法题需要多实践、思考和积累技巧来提升解题能力。

继续打卡算法题,今天学习的是第LeetCode的第11题盛最多水的容器,这道题目是道中等题,但是我感觉不像中等题。算法题的一些解题思路和技巧真的非常巧妙,每天看一看算法题和解题思路,我相信对我们的编码能力有一些帮助。

image.png

分析一波题目

其实我觉得这个题目很难,因为我一开始想不到它的诀窍。

如果要盛水更多,我们可以想到两点:

  1. 水柱越高,盛水越多
  2. 水柱越宽,盛水越多

两根水柱之间盛水的面积公式:

盛水面积 = Min(height[start], height[end]) * (end-start)

如果用穷举法,我们需要对每根水柱都遍历一遍,这样时间复杂度会达到O(n^2)

有没有技巧呢?其实是有的,我们可以想象下从两边往内找,同时有两个指针,如果我们每次只移动短水柱会有什么效果?

短水柱移动可能会导致面积变大,但是不会变小。因此我们可以使用双指针来解决此问题。

编码解决

class Solution {
   
   
    public int maxArea(int[] height) {
   
   

            //双指针法,有个规律,只能移动短板才可能导致面积变大,移动长板长度不变或变小,面积一定变小
            int res = 0;
            int start = 0;
            int end = height.length -1;

            while(start < end) {
   
   
               //水槽最大面积由短板面积决定
               int t =  Math.min(height[start], height[end]) * (end - start);
               res = Math.max(res, t);
               //移动短板
               if(height[start] < height[end]) {
   
   
                   start++;
               } else {
   
   
                   end--;
               }
            }
            return res;
    }
}

总结

很多算法类题目其实是有一些技巧性的解法的,如果靠暴力方法解决性能极低,通过一个技巧提升性能,我想这种技巧应该还是要多实践,多写,多思考,多积累,我相信一定可以积累一些解决技巧的。

相关文章
|
7月前
|
存储 容器
LeetCode刷题---11. 盛最多水的容器(双指针-对撞指针)
LeetCode刷题---11. 盛最多水的容器(双指针-对撞指针)
|
2月前
|
容器
Leetcode第十一题(盛最多水的容器)
LeetCode第十一题要求找出两条线,使得它们与x轴构成的容器能盛最多的水,通常使用双指针法来解决,通过移动较短的一边来尝试增加容量。
18 0
Leetcode第十一题(盛最多水的容器)
|
4月前
|
Python 容器
【Leetcode刷题Python】11. 盛最多水的容器
解决LeetCode "盛最多水的容器" 问题的Python实现代码,使用了双指针的方法来找出能够容纳最多水的两条线。代码中定义了两个指针i和j,分别从数组的两端向中间遍历,通过计算两个指针所指高度的较小值与它们之间的距离的乘积来更新最大面积res。
35 0
|
6月前
|
算法 测试技术 程序员
力扣经典150题解析之二十八:盛最多水的容器
力扣经典150题解析之二十八:盛最多水的容器
55 0
|
6月前
|
算法 容器
【LeetCode刷题】快乐数、盛水最多的容器
【LeetCode刷题】快乐数、盛水最多的容器
|
6月前
|
算法 容器
【经典LeetCode算法题目专栏分类】【第1期】左右双指针系列:盛最多水的容器、接雨水、回文子串、三数之和
【经典LeetCode算法题目专栏分类】【第1期】左右双指针系列:盛最多水的容器、接雨水、回文子串、三数之和
|
7月前
|
容器
leetcode代码记录(盛最多水的容器
leetcode代码记录(盛最多水的容器
31 1
|
7月前
|
算法 容器
【优选算法】—Leetcode—11—— 盛最多水的容器
【优选算法】—Leetcode—11—— 盛最多水的容器
|
7月前
|
容器
【力扣】11. 盛最多水的容器
【力扣】11. 盛最多水的容器