2461. Maximum Sum of Distinct Subarrays With Length K
Read the full problem statement on LeetCode.
Difficulty: medium Acceptance: 43% Topics: Array, Hash Table, Sliding Window
View full problem on LeetCode Reading material
Reference solution (spoiler · python)
# Time: O(n)
# Space: O(k)
# two pointers
class Solution(object):
def maximumSubarraySum(self, nums, k):
"""
:type nums: List[int]
:type k: int
:rtype: int
"""
result = left = total = 0
lookup = set()
for right in xrange(len(nums)):
while nums[right] in lookup or len(lookup) == k:
lookup.remove(nums[left])
total -= nums[left]
left += 1
lookup.add(nums[right])
total += nums[right]
if len(lookup) == k:
result = max(result, total)
return result
Solution from kamyu104/LeetCode-Solutions · MIT