【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;
	}
};
相关推荐
MC皮蛋侠客1 天前
Google Test 单元测试指南
c++·单元测试·google test
艾莉丝努力练剑1 天前
【Linux:文件】Ext系列文件系统进阶
linux·运维·服务器·c++·文件系统·文件io·ext
kkeeper~1 天前
0基础C语言积跬步之数据在内存中的存储
c语言·数据结构·算法
2401_868534781 天前
论企业网络设计
数据结构
wabs6661 天前
关于贪心算法的一些自我总结【力扣45.跳跃游戏II】【灵感来源:代码随想录】
算法·贪心算法·复盘
2401_876964131 天前
【湖北专升本】2026湖北专升本真题PDF+备考资料汇总
数据结构·人工智能·经验分享·深度学习·算法·计算机视觉
basketball6161 天前
C++ NULL 和 nullptr 区别 以及 nullptr 的核心实现
java·开发语言·c++
嗝o゚1 天前
CANN GE 算子融合——融合算法与调度策略
算法·昇腾·cann·ge
小江的记录本1 天前
【JVM虚拟机】垃圾回收GC:垃圾回收算法:标记-清除、标记-复制、标记-整理、分代收集(附《思维导图》+《面试高频考点清单》)
java·jvm·后端·python·算法·安全·面试
Fre丸子_1 天前
自定义文件夹选取功能
c++