算法4.0

11. 盛最多水的容器 - 力扣(LeetCode)

想简单了 审题时候补药着急 慢慢来 多试试几个例子

算法原理

解法1:暴力枚举 双层for循环 算出所有值然后找最大值(肯定超时的)

java 复制代码
public class Solution {
    public int maxArea(int[] height){
        int maxArea = 0;
        for (int i = 0; i <height.length ; i++) {
            for (int j = i+1; j <height.length; j++) {//j从j+1开始 避免重复计算
                int h = Math.min(height[i],height[j] );
                int w = j-i;  //宽度
                int area = h*w;
                if(area >maxArea){
                    maxArea = area;//更新最大值
                }
            }
        }
      return maxArea;
    }
}

解法2: 单调性 双指针

先找一个小区间研究

选择最边的两个 然后逐级向内 发现宽度一直在减小(永远都在减小)

如果拿6 和 4计算完成之后 接下来用4和2计算 4和5计算 宽度永远在减小(向内枚举)

高度变化:如果向内枚举的时候 碰到了比我小的数 高度也减小 宽度也在减小(向内枚举)

这个时候最终结果一定减小

如果向内枚举的时候 碰到了比我大的数 高度不变(最小的为水桶高度) 宽度在减小

这个时候最终结果一定减小

如果你的总体积是减小的 我要的是盛水最多的容器 那么中间2 和 5 就不需要枚举了

因为这个时候 最边的6和4就是记录的最大的容器 所以干掉4

规律扩大

直接用题目给的数组开干

用最左边和最右边先计算 计算完记录结果V1之后干掉左面(上面研究的那个例子证明一定减小)

第二部分直接干掉7 循环往复 慢慢干掉所有 下面是图片展示过程

定义两个箭头 就是抽象成了双指针

利用单调性 使用双指针 遍历数组一遍就找到最终结果(时间复杂度从n的平方直接变成n)

下面是效果图和代码:

java 复制代码
class Solution {
    public int maxArea(int[] height) {
        int maxArea =0;
        int behind = 0 ,back=height.length-1;
        while(behind != back) {
          if(height[behind]<height[back]){
            int area = height[behind]*(back-behind);
             if(area>maxArea){
                maxArea = area ;
             }
              behind++;
          }else{
            int area = height[back]*(back-behind);
             if(area>maxArea){
                maxArea = area ;
             }
            back--;
          }
        }
        return maxArea;
    }
}//xiyu251010&1#1*4
相关推荐
mingo_敏26 分钟前
Mean-Teacher 均值教师自训练框架详解
算法·均值算法
星空露珠1 小时前
迷你世界UGc3.0脚本Wiki[剧情动画模块管理接口 Timeline]
开发语言·数据结构·算法·游戏·lua
笨笨没好名字1 小时前
Leetcode刷题python3版第一周(下)
linux·算法·leetcode
手写码匠1 小时前
手写 LLM 安全护栏:从内容审核到越狱防御的完整实现
人工智能·深度学习·算法·aigc
luj_17681 小时前
草酸与烟酸对消化及糖代谢的影响解析
服务器·c语言·开发语言·经验分享·算法
青风971 小时前
16-ADAPTRACK:基于自适应阈值的多目标跟踪匹配算法
人工智能·算法·目标跟踪
汤姆yu2 小时前
macOS系统下Aider完整安装、配置与实战使用教程
大数据·人工智能·算法·macos·github·copilot
Sam09272 小时前
【AI 算法精讲 14】TF-IDF:词频与逆文档频率
人工智能·python·算法·ai
AI科技星2 小时前
拓扑生命系统确定性理论:基于32维流形的遗传密码起源与衰老动力学( 中英双语顶刊终稿·标准数学符号)
开发语言·网络·人工智能·算法·机器学习·乖乖数学·全域数学
编程圈子2 小时前
电机驱动开发学习18. SVPWM空间矢量调制算法详解与实现
驱动开发·学习·算法