Leetcode 974. 和可被 K 整除的子数组

文章解析了LeetCode题目974的方法,利用哈希表存储数组中每个子数组结束时的余数,通过计算余数变化来确定有多少子数组和能被K整除。答案即为哈希表中对应余数的计数。
摘要由CSDN通过智能技术生成

题目

在这里插入图片描述
Leetcode 974. 和可被 K 整除的子数组

代码(8.3 首刷看解析 GO)

(preSum[j+1]-preSum[i]) % k=0, 根据分配率得preSum[j+1] % k = preSum[i] % k,说明我们哈希表要存储的是余数。同样的,一开始余数为0的个数为1。

且由于答案求的是个数,所以我们就将哈希表的value值记作个数。一般答案求什么,value就是什么

func subarraysDivByK(nums []int, k int) int {
    pre, res := 0, 0
    mp := map[int]int{0:1}
    for _, v := range(nums) {
        pre += v
        left := (pre % k + k) % k   // 负数的余数不一样
        if _, ok := mp[left]; ok {
            res += mp[left]
        }
        mp[left]++
    }
    return res;
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值