209. 长度最小的子数组¶
力扣链接(中等):https://leetcode.cn/problems/minimum-size-subarray-sum
给定一个含有 n
个正整数的数组和一个正整数 target
。
找出该数组中满足其总和大于等于 target
的长度最小的 子数组 [numsl, numsl+1, ..., numsr-1, numsr]
,并返回其长度。如果不存在符合条件的子数组,返回 0
。
示例 1:
示例 2:
示例 3:
提示:
1 <= target <= 109
1 <= nums.length <= 105
1 <= nums[i] <= 104
进阶:
- 如果你已经实现
O(n)
时间复杂度的解法, 请尝试设计一个O(n log(n))
时间复杂度的解法。
个人题解¶
官方题解¶
为了降低时间复杂度,可以使用滑动窗口的方法。
定义两个指针 start
和 end
分别表示子数组(滑动窗口窗口)的开始位置和结束位置,维护变量 sum
存储子数组中的元素和(即从 nums[start]
到 nums[end]
的元素和)。
初始状态下,start
和 end
都指向下标 0
,sum
的值为 0
。
每一轮迭代,将 nums[end]
加到 sum
,如果 sum≥s
,则更新子数组的最小长度(此时子数组的长度是 end−start+1
),然后将 nums[start]
从 sum
中减去并将 start
右移,直到 sum<s
,在此过程中同样更新子数组的最小长度。在每一轮迭代的最后,将 end
右移。
复杂度分析¶
时间复杂度:\(O(n)\),其中 n
是数组的长度。指针 start
和 end
最多各移动 n
次。
空间复杂度:\(O(1)\)。