【Golang】LeetCode 560. 和为 K 的子数组

560. 和为 K 的子数组

题目描述

思路

看到这道题目我们可能会想到使用滑动窗口来解题:设置两个指针来对窗口进行维护,不断地移动右指针并将右指针指向的数值累加到sum当中,如果sum > k,就开始移动左指针并减去左指针对应的数的数值。但是这个思路是错误的,原因就是数组当中可能存在负数,基于窗口的和与目标数值比大小没有意义。

正确的做法应该是基于前缀和来判断数组中是否有连续的子数组和为k,我们只需要记录每个前缀和出现的频率即可,我们设置一个字典mp来对前缀和出现的频率进行统计,用prefix来在遍历数组的过程中对前缀和进行维护。如果prefix - kmp当中出现过,就代表着当前数组中存在一个子数组,其和为k。由于数组当中可能存在负数,因此我们通过mp对前缀和出现的频率进行统计,这种情况下我们令答案ansmp[prefix - k]进行累加即可。

基于以上思路,我们写代码来解决问题。

Golang 题解

go 复制代码
func subarraySum(nums []int, k int) int {
    mp := map[int]int{}
    mp[0] = 1

    n, prefix, ans := len(nums), 0, 0
    for i := 0; i < n; i ++ {
        prefix += nums[i]
        if cnt, ok := mp[prefix - k]; ok {
            ans += cnt
        }
        mp[prefix] += 1
    }

    return ans
}

Python 题解

python 复制代码
class Solution:
    def subarraySum(self, nums: List[int], k: int) -> int:
        mp = dict()
        mp[0] = 1

        n, prefix, ans = len(nums), 0, 0
        for num in nums:
            prefix += num
            if prefix - k in mp:
                ans += mp[prefix - k]

            if prefix not in mp:
                mp[prefix] = 0

            mp[prefix] += 1
        
        return ans
相关推荐
千寻girling5 小时前
Python 是用来做 AI 人工智能 的 , 不适合开发 Web 网站 | 《Web框架》
人工智能·后端·算法
颜酱9 小时前
一步步实现字符串计算器:从「转整数」到「带括号与优化」
javascript·后端·算法
CoovallyAIHub1 天前
语音AI Agent编排框架!Pipecat斩获10K+ Star,60+集成开箱即用,亚秒级对话延迟接近真人反应速度!
深度学习·算法·计算机视觉
木心月转码ing1 天前
Hot100-Day14-T33搜索旋转排序数组
算法
会员源码网1 天前
内存泄漏(如未关闭流、缓存无限增长)
算法
颜酱1 天前
从0到1实现LFU缓存:思路拆解+代码落地
javascript·后端·算法
颜酱1 天前
从0到1实现LRU缓存:思路拆解+代码落地
javascript·后端·算法
CoovallyAIHub2 天前
Moonshine:比 Whisper 快 100 倍的端侧语音识别神器,Star 6.6K!
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
速度暴涨10倍、成本暴降6倍!Mercury 2用扩散取代自回归,重新定义LLM推理速度
深度学习·算法·计算机视觉