前往小程序,Get更优阅读体验!
立即前往
发布
社区首页 >专栏 >【优选算法】9----长度最小的子数组

【优选算法】9----长度最小的子数组

作者头像
用户11456817
发布2025-01-25 20:02:34
发布2025-01-25 20:02:34
6600
代码可运行
举报
文章被收录于专栏:学习学习
运行总次数:0
代码可运行

题目解析:

重点:在学习滑动窗口这一类算法题前,我们需要了解一个概念:“滑动窗口”是什么?

我们来用寻宝藏来设想一下:

滑动窗口就像是一个会自动调整大小的“魔法窗口”,在数组上滑动,寻找宝藏。它能大大减少不必要的计算,效率比暴力解法高多了。

讲解算法原理:

方法一:暴力解法:简单粗暴的大搜索

这题的解题思路就像是找宝藏,一开始咱两眼一抹黑,不知道宝藏在哪,那就得从最开始的地方一

点点摸索。

暴力解法很直接,就是把所有可能的子数组都找出来,计算它们的和,看看哪个子数组的和大于等

于 target ,然后找出其中长度最小的。这就好比把整个森林里的每一个角落都翻个遍,肯定能找

到宝藏,但就是有点费时间和精力。

方法二:聪明的寻宝法

这里的 left 和 right 就是滑动窗口的左右边界。一开始,窗口大小为 0 ,也就是 left 和 right 都在

数组的起始位置。然后,right 开始向右移动,就像把窗口一点点扩大,把新的数字装进窗口里,

同时累加窗口内数字的和。当窗口内数字的和大于等于 target 时,就说明找到了一个可能的“宝藏

序列”,这时候就尝试把窗口左边的边界 left 向右移动,看看能不能把窗口缩小,同时保持和大于

等于 target 。每缩小一次,就更新一下最小长度。这样不断地滑动窗口,就能找到满足条件的最

小子数组长度啦。

滑动窗口的时间复杂度是 O(n) ,因为每个元素最多进窗口和出窗口各一次,效率比暴力解法高了

不知道多少倍,就像开着跑车在森林里找宝藏,又快又准!

编写代码:

方法二如下所示:

代码语言:javascript
代码运行次数:0
复制
​
​
class Solution {
public:
    int minSubArrayLen(int target, vector<int>& nums) {
       int n=nums.size(),sum=0,len=INT_MAX;
       for(int right =0,left=0;right<n;right++)
       {
        sum+=nums[right];
        while(sum>=target)
        {
            len=min(len,right-left+1);
            sum-=nums[left++];
        }
       }
       return len==INT_MAX?0:len;
    }
};

​

​

这道长度最小的子数组题目,通过暴力解法和滑动窗口两种思路的对比,让我们看到了算法优化的

魅力。暴力解法虽然简单易懂,但在效率上输给了滑动窗口。就像生活中,有时候简单直接的方法

虽然能解决问题,但多花点心思,找到更巧妙的方法,往往能事半功倍。

希望大家都能学会这个滑动窗口的技巧,以后再遇到类似的问题,就能轻松解决啦!

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2025-01-24,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 题目解析:
  • 讲解算法原理:
  • 编写代码:
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档