LeetCode第11题盛最多水的容器

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

分析一波题目

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

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

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

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

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

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

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

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

编码解决

java 复制代码
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;
    }
}

总结

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

相关推荐
pzx_00115 分钟前
【LeetCode】14. 最长公共前缀
算法·leetcode·职场和发展
self_myth16 分钟前
算法与数据结构实战技巧:从复杂度分析到数学优化
算法
程序新视界36 分钟前
在职场,尽量不要成为这样的“人才”
面试·求职
小奋斗1 小时前
以Chrome 为代表的浏览器架构详解
面试·程序员
songx_991 小时前
leetcode10(跳跃游戏 II)
数据结构·算法·leetcode
在未来等你1 小时前
Elasticsearch面试精讲 Day 12:数据建模与字段类型选择
大数据·分布式·elasticsearch·搜索引擎·面试
a587691 小时前
消息队列(MQ)初级入门:详解RabbitMQ与Kafka
java·分布式·microsoft·面试·kafka·rabbitmq
先做个垃圾出来………2 小时前
差分数组(Difference Array)
java·数据结构·算法
hansang_IR2 小时前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乐迪信息2 小时前
乐迪信息:AI摄像机在智慧煤矿人员安全与行为识别中的技术应用
大数据·人工智能·算法·安全·视觉检测