LeetCode - LCR 008.长度最小的子数组

一. 题目链接

LeetCode - 209. 长度最小的子数组

二. 思路分析

由于此问题分析的对象是「⼀段连续的区间」,因此可以考虑**「滑动窗口」**的思想来解决这道题。 让滑动窗口满足:从 i 位置开始,窗口内所有元素的和小于target (那么当窗口内元素之和 第⼀次大于等于目标值的时候,就是i 位置开始,满足条件的最小长度)。

做法:将右端元素划入窗口中,统计出此时窗口内元素的和:

**如果窗口内元素之和大于等于target :**更新结果,并且将左端元素划出去,继续判断是否满足条件并更新结果(因为左端元素可能很小,划出去之后依旧满足条件)

如果窗口内元素之和不满足条件: right++ ,另下⼀个元素进入窗口。

为何滑动窗口可以解决问题,并且时间复杂度更低?

这个窗口寻找的是:以当前窗口最左侧元素(记为 left1 )为基准,符合条件的情况。也 就是在这道题中,从left1 开始,满租区间和sum >= target 时的最右侧(记为 right1 )能到哪里。

我们既然已经找到从left1 开始的最优的区间,那么就可以⼤胆舍去left1 。但是如 果继续像⽅法⼀⼀样,重新开始统计第⼆个元素( left2 )往后的和,势必会有⼤量重复 的计算(因为我们在求第⼀段区间的时候,已经算出很多元素的和了,这些和是可以在计算 下次区间和的时候⽤上的)。

此时, rigth1 的作用就体现出来了,我们只需将left1 这个值从sum 中剔除。从 right1 这个元素开始,往后找满足left2 元素的区间(此时right1 也有可能是满 ⾜的,因为left1 可能很⼩。 sum 剔除掉left1 之后,依旧满足大于等于 target )。这样我们就能省掉大量重复的计算。

三. 动画分析

四. 代码解释

cpp 复制代码
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) 
    {
        int left = 0;
        int right = 0;
        int len = INT_MAX;
        int res = 0;
        while (right < nums.size())
        {
            res += num[right++];
                while (res > target)
                {
                    len = min(len,right - left +1);
                    sum -= num[left--];
                }
                return len = INT_MAX ?0 : len;
        }
    }
};
相关推荐
kobesdu9 小时前
人形机器人SLAM:技术挑战、算法综述与开源方案
算法·机器人·人形机器人
椰羊~王小美11 小时前
随机数概念及算法
算法
阿Y加油吧11 小时前
算法实战笔记:LeetCode 169 多数元素 & 75 颜色分类
笔记·算法·leetcode
不要秃头的小孩11 小时前
力扣刷题——509. 斐波那契数
python·算法·leetcode·动态规划
We་ct12 小时前
LeetCode 120. 三角形最小路径和:动态规划详解
前端·javascript·算法·leetcode·typescript·动态规划
py有趣12 小时前
力扣热门100题之和为K的子数组
数据结构·算法·leetcode
hipolymers13 小时前
C语言怎么样?难学吗?
c语言·数据结构·学习·算法·编程
workflower14 小时前
机器人应用-楼宇室内巡逻
大数据·人工智能·算法·microsoft·机器人·动态规划·享元模式
ZPC821014 小时前
fanuc 机器人通过PR寄存器实现轨迹控制
人工智能·算法·计算机视觉·机器人