Leetcode 892 Solution

This article provides solution to leetcode question 892 (shortest-subarray-with-sum-at-least-k).

https://leetcode.com/problems/shortest-subarray-with-sum-at-least-k

Solution

class Solution(object):
    def shortestSubarray(self, A, K):
        """
        :type A: List[int]
        :type K: int
        :rtype: int
        """
        S = [0]
        for a in A:
            S.append(a + S[-1])

        q = collections.deque()

        ans = len(A) + 1
        for i, s in enumerate(S):
            while q and S[q[-1]] >= s:
                q.pop()

            while q and s - S[q[0]] >= K:
                ans = min(i - q[0], ans)
                q.popleft()

            q.append(i)

        return ans if ans <= len(A) else -1