【LeetCode滑动窗口算法】长度最小的子数组 难度:中等

我们先看一下题目描述:

解法一:暴力枚举

时间复杂度:o(n^3)

cpp 复制代码
class Solution {
public:
	int minSubArrayLen(int target, vector<int>& nums)
	{
		int i = 0, j = 0;
		vector<int> v;
		for (;i < nums.size();i++)
		{
			int sum = nums[i];
			for (j = i + 1;j < nums.size();j++)
			{
				sum = sum + nums[j];
				if (target == sum)
				{
					v.push_back(j - i + 1);//j-i+1就是满足条件的子数组的长度
					break;
				}
			}
		}
		sort(v.begin(), v.end());
		if (v.empty())
			return 0;
		else
			return v[0];
	}
};

解法2:利用数组元素的单调性,滑动窗口(同向双指针)算法。

时间复杂度: o(n)

滑动窗口怎么用呢?

1、left=0,right=0

2、进窗口-->判断是否满足条件-->否-->进窗口

是-->更新结果-->出窗口-->更新结果

滑动窗口算法主要是利用数组元素之和的单调性,规避了很多没有必要的枚举行为。

下面是滑动窗口算法的演示:

下面我们来实现一下基于滑动窗口算法的解题代码:

cpp 复制代码
class Solution {
public:
	int minSubArrayLen(int target, vector<int>& nums)
	{
		int sum = 0, len = INT_MAX;
		for (int left = 0, right = 0;right < nums.size();right++)
		{
			sum += nums[right];//进入窗口
			while (sum >= target)//判断
			{
				len = min(len, right - left + 1);//更新结果
				sum -= nums[left++];//出窗口
			}
		}
		return len == INT_MAX ? 0 : len;
	}
};
相关推荐
Dream it possible!33 分钟前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi34 分钟前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L38 分钟前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先
铁手飞鹰43 分钟前
二叉树(C语言,手撕)
c语言·数据结构·算法·二叉树·深度优先·广度优先
麦烤楽鸡翅2 小时前
简单迭代法求单根的近似值
java·c++·python·数据分析·c·数值分析
专业抄代码选手2 小时前
【Leetcode】1930. 长度为 3 的不同回文子序列
javascript·算法·面试
[J] 一坚3 小时前
深入浅出理解冒泡、插入排序和归并、快速排序递归调用过程
c语言·数据结构·算法·排序算法
czlczl200209253 小时前
算法:二叉搜索树的最近公共祖先
算法
司铭鸿3 小时前
祖先关系的数学重构:从家谱到算法的思维跃迁
开发语言·数据结构·人工智能·算法·重构·c#·哈希算法
yk0820..3 小时前
测试用例的八大核心要素
数据结构