给定一个含有 n 个正整数的数组和一个正整数 s ,找出该数组中满足其和 ≥ s 的长度最小的 连续 子数组,并返回其长度。如果不存在符合条件的子数组,返回 0。
示例:
输入:s = 7, nums = [2,3,1,2,4,3]
输出:2
解释:子数组 [4,3] 是该条件下的长度最小的子数组。
提示:
1 <= target <= 10^9
1 <= nums.length <= 10^5
1 <= nums[i] <= 10^5
滑动窗口的方法
cpp
class Solution {
public:
int minSubArrayLen(int target, vector<int>& nums) {
int result=INT32_MAX;
int sum=0;//滑动窗口内的和
int i=0;//oriented position
int length=0;//滑动窗口长度
for(int j=0;j<nums.size();j++)//end position
{
sum+=nums[j];//滑动窗口的数组和
while(sum>=target)
{
length=j-i+1;
result=result<length?result:length;
sum-=nums[i++];//窗口始端往前移动
}
}
return result==INT32_MAX?0:length;
}
};
相关题目
904
76