862 Shortest Subarray with Sum at Least K
1. Question
Return the length of the shortest, non-empty, contiguous subarray ofA
with sum at leastK
.
If there is no non-empty subarray with sum at leastK
, return-1
.
Example 1:
Example 2:
Example 3:
Note:
1 <= A.length <= 50000
-10 ^ 5 <= A[i] <= 10 ^ 5
1 <= K <= 10 ^ 9
2. Implementation
(1) Deque
思路:
要得到subarray sum,我们需要先构建prefixSum数组,通过prefixSum数组,我们可以迅速的得到subarray[i, j]的和是prefixSum[j - 1] - prefixSum[i]
由于题目要我们找到最短的subarray,且subarray和大于等于K,所以我们可以通过一个双向队列deque,当deque不为空且prefixSum[i] - prefixSum[deque.getFirst()] 大于等于K时,我们得到一个解,更新res
同时我们需要注意数组会存在负数或者0的情况,在这种情况下,如果prefixSum[i] <= prefixSum[dequeu.getLast()],由于i > deque.getLast(), prefixSum[i]比prefixSum[deque.getLast()]小,说明从i开始的区间不仅比deque.getLast()开始的区间更有机会比K大,同时最后得到的区间也会更小,所以我们可以删除deque.getLast()上的位置,而保留i
3. Time & Space Complexity
Deque: 时间复杂度O(n), 空间复杂度O(n)
Last updated
Was this helpful?