【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;
	}
};
相关推荐
司铭鸿9 分钟前
图论中的协同寻径:如何找到最小带权子图实现双源共达?
linux·前端·数据结构·数据库·算法·图论
橘子真甜~18 分钟前
C/C++ Linux网络编程6 - poll解决客户端并发连接问题
服务器·c语言·开发语言·网络·c++·poll
铭哥的编程日记34 分钟前
【标准项目】C++基于正倒排索引的Boost搜索引擎
c++·搜索引擎
码力码力我爱你1 小时前
C++性能基准测试
开发语言·c++
小年糕是糕手2 小时前
【C++】C++入门 -- 输入&输出、缺省参数
c语言·开发语言·数据结构·c++·算法·leetcode·排序算法
情怀姑娘2 小时前
面试题---------------场景+算法
java·算法·mybatis
chbmvdd2 小时前
week5题解
数据结构·c++·算法
用户12039112947262 小时前
面试官最爱问的字符串反转:7种JavaScript实现方法详解
算法·面试
vir022 小时前
小齐的技能团队(dp)
数据结构·c++·算法·图论
月夜的风吹雨3 小时前
【C++红黑树】:自平衡二叉搜索树的精妙实现
开发语言·c++·红黑树