Skip to content
LC-3026 Medium LeetCode

3026. Maximum Good Subarray Sum

Read the full problem statement on LeetCode.
Difficulty: medium Acceptance: 20% Topics: Array, Hash Table, Prefix Sum
View full problem on LeetCode
Reference solution (spoiler · python)
# Time:  O(n)
# Space: O(n)

import collections


# prefix sum
class Solution(object):
    def maximumSubarraySum(self, nums, k):
        """
        :type nums: List[int]
        :type k: int
        :rtype: int
        """
        prefix = collections.defaultdict(lambda: float("inf"))
        curr = 0
        result = float("-inf")
        for x in nums:
            prefix[x] = min(prefix[x], curr)
            curr += x
            result = max(result, curr-prefix[x-k], curr-prefix[x+k])
        return result if result != float("-inf") else 0

Solution from kamyu104/LeetCode-Solutions · MIT