滑动窗口实例1(长度最小的子数组)

这篇具有很好参考价值的文章主要介绍了滑动窗口实例1(长度最小的子数组)。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

题目:

给定一个含有 n 个正整数的数组和一个正整数 target 。

找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, ..., numsr-1, numsr] ,并返回其长度如果不存在符合条件的子数组,返回 0 。

示例 1:

输入:target = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。

示例 2:

输入:target = 4, nums = [1,4,4]
输出:1

示例 3:

输入:target = 11, nums = [1,1,1,1,1,1,1,1]
输出:0

提示:

  • 1 <= target <= 109
  • 1 <= nums.length <= 105
  • 1 <= nums[i] <= 105

算法原理:

暴力解法基础上的优化:

暴力解法是依次固定左边界,从左边界开始依次作为右边界加入sum,计算和,当和>=target且小于上一次的结果就更新结果

暴力解法存在很多不必要且重复的计算:

滑动窗口实例1(长度最小的子数组),算法合集,算法

滑动窗口(优解):

 滑动窗口其实就是同向指针,left指针和right指针都不会回退

初始化:left=0 (左边界)right=0(待进入窗口的数值)

1 进窗口:让right指针指向的数值加入sum中

2 判断:若是sum>=target(已是当前left指向数值作为左边界找到的满足条件的最短连续子数组,right指针没必要往后面走,再让sum加入一些数值,因为只要再加入数值,一定是比target大的,但是又增加了长度,所以没必要)  且比上一次的结果要小则更新结果

 3 出窗口:left指向的数值作为左边界已有自己的最优结果,sum-=nums[left++]

    重复步骤2的判断,因为出了原先的nums[left] ,新数值作为左边界时也可能已经满足条件              sum>=target(right指针依然是原nums[left]做左边界时,能够找到的最优右边界),如right指向的数值加入后使得sum远远大于target,那么出了一个元素,可能会使得剩下的元素依然>=target

4 结束条件:right>=n 

滑动窗口实例1(长度最小的子数组),算法合集,算法

代码实现:

 

class Solution 
{
public:
    int minSubArrayLen(int target, vector<int>& nums)
    {
        int sum = 0;
        int len = INT_MAX;//注意不能初始化为0,因为是找最小
        int left = 0;
        int right = 0;
        int n = nums.size(); 
        while(right<n)
        {
            sum+=nums[right];//进窗口
            while(sum>=target)//判断
            {
                len = min(len,right-left+1);//更新结果
                sum-=nums[left++];//出窗口
            }
            right++;
        }
        return len==INT_MAX?0:len;
    }
};

            文章来源地址https://www.toymoban.com/news/detail-681717.html

到了这里,关于滑动窗口实例1(长度最小的子数组)的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包 赞助服务器费用

相关文章

  • 【Leetcode刷题-Python/C++】长度最小的子数组(滑动窗口)

    209.长度最小的子数组 给定一个含有 n 个正整数的数组和一个正整数 target 。 找出该数组中满足其和 ≥ target 的长度最小的 连续子数组 [numsl, numsl+1, …, numsr-1, numsr] ,并返回其长度。如果不存在符合条件的子数组,返回 0 。 输入:target = 7, nums = [2,3,1,2,4,3] 输出:2 解释:子数

    2023年04月08日
    浏览(31)
  • 【滑动窗口】长度最小的子数组|无重复字符的最长子串|最大连续1的个数 III|将 x 减到 0 的最小操作数

    1. 长度最小的子数组 - 力扣(LeetCode) (1)方法一:暴力列举出所有的子数组的和 时间复杂度:O(n**2):枚举所有子数组O(n**2) (2)方法二: 利用 单调性(两个指针都不回退) ,使用\\\" 同向双指针 \\\"(其实就是 滑动窗口 )来优化 那么 滑动窗口过程 是怎么样的? 1le

    2024年03月22日
    浏览(41)
  • 「优选算法刷题」:长度最小的子数组

    给定一个含有  n   个正整数的数组和一个正整数  target  。 找出该数组中满足其总和大于等于   target   的长度最小的  连续子数组   [numsl, numsl+1, ..., numsr-1, numsr]  ,并返回其长度 。 如果不存在符合条件的子数组,返回  0  。 示例 1: 示例 2: 示例 3: 这道题也是一道

    2024年01月23日
    浏览(29)
  • 算法-有序数组的平方,长度最小的子数组,螺旋矩阵II

    伪装成一个老手! 题目 给你一个按 非递减顺序 排序的整数数组 nums,返回每个数字的平方组成的新数组,要求也按非递减顺序排序。 示例 : 输入:nums = [-4,-1,0,3,10] 输出:[0,1,9,16,100] 解释:平方后,数组变为 [16,1,0,9,100] 排序后,数组变为 [0,1,9,16,100] 来源:力扣977 思路 遍

    2024年02月11日
    浏览(27)
  • 算法练习-长度最小的子数组(思路+流程图+代码)

            难度:简单         分类:数组         难度与分类由我所参与的培训课程提供,但需要注意的是,难度与分类仅供参考。以下内容均为个人笔记,旨在督促自己认真学习。         给定一个含有个正整数的数组和一个正整数s,找出该数组中满足其和

    2024年01月18日
    浏览(30)
  • java数据结构与算法刷题-----LeetCode209. 长度最小的子数组

    java数据结构与算法刷题目录(剑指Offer、LeetCode、ACM)-----主目录-----持续更新(进不去说明我没写完): https://blog.csdn.net/grd_java/article/details/123063846 解题思路 代码:时间复杂度O(n).空间复杂度O(1)

    2024年01月21日
    浏览(33)
  • 算法训练 Day 2 | 数组:977.有序数组的平方,209.长度最小的子数组,59.螺旋矩阵II

    977. 有序数组的平方 第一想法:暴力破解 看完题解想法:朝着双指针方向想 遇到困难: 用双指针的话,一开始想到两边指针往中间靠,逐个将最大值赋给结果数组。和题解不同的是,循环条件我写了  while (left != right) {...} ,相比于题解的  while (left = right) {...} ,我需要在后

    2023年04月12日
    浏览(36)
  • 4、长度最小的子数组

            找到一个数组中,有多少个连续元素的和小于某个值,求出连续元素的长度的最小值。         其本质也是快慢指针,一个指针指向窗口的起始位置,另一个指针指向窗口的终止位置。     1.定义快慢指针: 2.更新慢指针: 并记录长度 3. 更新快指针: 4.重复第二步

    2024年02月14日
    浏览(22)
  • 209. 长度最小的子数组

    给定一个含有  n   个正整数的数组和一个正整数  target  。 找出该数组中满足其和   ≥ target   的长度最小的  连续子数组   [numsl, numsl+1, ..., numsr-1, numsr]  ,并返回其长度 。 如果不存在符合条件的子数组,返回  0  。 示例 1: 示例 2: 示例 3: 提示: 1 = target = 109 1 =

    2024年02月16日
    浏览(26)
  • 【Leetcode】209. 长度最小的子数组

    给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组,并返回其长度。如果不存在符合条件的子数组,返回 0。 示例: 输入:s = 7, nums = [2,3,1,2,4,3] 输出:2 解释:子数组 [4,3] 是该条件下的长度最小的子数组。 提示:

    2024年02月13日
    浏览(24)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包