欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

560. 和为K的子数组(中等)- LeetCode

程序员文章站 2022-04-17 13:21:44
...

题目描述

560. 和为K的子数组(中等)- LeetCode

自己解法

解法一:暴力求解,时间复杂度O(n2)O(n^2),空间复杂度O(1)O(1)

class Solution:
    def subarraySum(self, nums: List[int], k: int) -> int:
        ans = 0
        L = len(nums)
        for i,val in enumerate(nums):
            remain = k - val
            if remain == 0:
                ans += 1
            for j in range(i+1,L):
                remain -= nums[j]
                if remain == 0:
                    ans += 1
        return ans

560. 和为K的子数组(中等)- LeetCode

解法二:哈希表+前缀和求解,时间复杂度O(n)O(n),空间复杂度O(n)O(n)

class Solution:
    def subarraySum(self, nums: List[int], k: int) -> int:
        mp = {0:1}
        ans,pre = 0,0
        for i,val in enumerate(nums):
            pre += val
            if pre - k in mp:
                ans += mp[pre-k]
            mp[pre] = mp.get(pre,0) + 1
        return ans 

560. 和为K的子数组(中等)- LeetCode
官方解答参考:链接

上一篇: 62. 不同路径

下一篇: 62. 不同路径

推荐阅读