滑动窗口——长度最小子数组

什么是滑动窗口 ?

滑动窗口,也称为双指针,但这个双指针是同向移动,适用于一些具有单调性的问题。也类似于暴力枚举,但并不是都要一一枚举。

滑动窗口的解题思路基本为:定义双指针,进窗口,判断,出窗口,更新结果

题目:

根据滑动窗口,我们来说一下思路:先定义两个指针指向头,然后left不变,每次对right及之前的数字求和然后right++(求得left和right之间的和)。我们以示例1为例:

两个指针的移动规则时,只要sum<target,我就让right++直到求和≥target。当发生此情况时,让left++然后重新计算二者之间的和(求和的方法我们可以用上一次的和-nums[left-1]。二者之间的区域我们就可以看成窗口在之间滑动,left每移动一次(符合条件的子数组),就记录一下当前的窗口长度。然后比较每一次的长度取min,直到right走到结尾。

我们发现,滑动窗口对于此题就相当于帮我们省去没必要的遍历,就以上图为例,此时sum=8,那么我就没必要枚举让right右移的所有子数组了(枚举的话虽然也一定符合target但是长度不是最短)。

cpp 复制代码
int Solution(vector<int<&nums,int target)
{

   int n=nums.size(),sum=0,len=INT_MAX;
   for(int left=0,right=0;right<n;right++)
     {
        sum+=nums[right];//窗口右扩
        while(sum>=target)
        {
          len=min(len,right-left);
          sum-=nums[left++];//窗口左缩
        }
     }
  
  return len==INT_MAX? 0 :len; //防止整个数组都不满足的情况
}
相关推荐
编程绿豆侠2 小时前
力扣HOT100之二分查找: 34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
Shan12052 小时前
找到每一个单词+模拟的思路和算法
数据结构·算法
国家不保护废物2 小时前
微信红包算法深度解析:从产品思维到代码实现
javascript·算法·面试
小明同学012 小时前
[C++入门]简化的艺术---对模版的初步探索
开发语言·c++·算法
kaiaaaa3 小时前
算法训练第八天
算法
LL_xjbt3 小时前
代码随想录刷题day29
算法·leetcode·动态规划
叶子2024223 小时前
守护进程实验——autoDL
人工智能·算法·机器学习
半桔4 小时前
【算法深练】分组循环:“分”出条理,化繁为简
数据结构·c++·算法·leetcode·面试·职场和发展
天天爱吃肉82184 小时前
【十年技术演进深度解构:车载充电机(OBC)将成为新能源汽车的“能源大脑”】
python·嵌入式硬件·算法·汽车·能源
KerwinChou_CN4 小时前
自由开发者计划 004:创建一个苹果手机长截屏小程序
图像处理·算法·智能手机·小程序