[523][中等][前缀和][哈希] 连续的子数组和
题目描述
输入:[23,2,4,6,7], k = 6
输出:True
解释:[2,4] 是一个大小为 2 的子数组,并且和为 6。输入:[23,2,6,4,7], k = 6
输出:True
解释:[23,2,6,4,7]是大小为 5 的子数组,并且和为 42。解题思路
最后更新于
输入:[23,2,4,6,7], k = 6
输出:True
解释:[2,4] 是一个大小为 2 的子数组,并且和为 6。输入:[23,2,6,4,7], k = 6
输出:True
解释:[23,2,6,4,7]是大小为 5 的子数组,并且和为 42。最后更新于
class Solution:
def checkSubarraySum(self, nums: List[int], k: int) -> bool:
mapping = {0: -1}
total = 0
for i, num in enumerate(nums):
total += num
if k != 0:
total = total % k
if total in mapping:
if i - mapping[total] >= 2:
return True
else:
mapping[total] = i
return False