专题四_前缀和(3)

目录

[560. 和为 K 的子数组](#560. 和为 K 的子数组)

解析

题解

[974. 和可被 K 整除的子数组](#974. 和可被 K 整除的子数组)

解析

题解


560. 和为 K 的子数组

560. 和为 K 的子数组 - 力扣(LeetCode)

解析

题解

cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        // 030_专题四_前缀和_和为 k 的子数组_C++
        unordered_map<int, int> hash; // 统计前缀和出现的次数
        int sum = 0, ret = 0;
        hash[0] = 1; // 预处理整个数组的前缀和就是K
        for (int x : nums)
        {
            sum += x; // 计算当前位置的前缀和
            if (hash.count(sum - k)) ret += hash[sum - k];
            hash[sum]++;
        }
        return ret;
    }
};

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

974. 和可被 K 整除的子数组 - 力扣(LeetCode)

解析

题解

cpp 复制代码
class Solution {
public:
    int subarraysDivByK(vector<int>& nums, int k) {
        // 031_专题四_前缀和_和可被 k 整除的子数组_C++
        unordered_map<int, int> hash;
        int sum = 0, ret = 0;
        hash[0] = 1;
        for (int x : nums)
        {
            sum += x; // 当前位置的前缀和
            int r = (sum % k + k) % k; // 修正后的余数
            if (hash.count(r)) ret += hash[r]; // 统计结果
            hash[r]++;
        }
        return ret;
    }
};
相关推荐
三斗米18 小时前
Transformer入门:一文读懂《Attention Is All You Need》
算法·架构
Swift社区18 小时前
LeetCode 458 - 可怜的小猪
算法·leetcode·职场和发展
AI科技星18 小时前
宇宙的像素:真空中一点如何编码无限星光
数据结构·人工智能·算法·机器学习·重构
程芯带你刷C语言简单算法题18 小时前
Day37~求组合数
c语言·开发语言·学习·算法·c
程序员-周李斌18 小时前
transmittable-thread-local[线程池跨线程值传递]
java·开发语言·算法·散列表
Flash.kkl18 小时前
优先算法专题十七——多源BFS
算法·宽度优先
Yzzz-F18 小时前
牛客小白月赛 D[差分] E [暴力枚举] F[] g[二阶差分]
算法
liliangcsdn18 小时前
DDPM前向加噪过程详细推导
人工智能·算法·机器学习
没有bug.的程序员19 小时前
Sentinel 流控原理深度解析:构建高可用微服务的底层架构
java·算法·微服务·云原生·架构·sentinel·负载均衡
深圳佛手19 小时前
IVFFlat 与 HNSW 算法介绍与对比
人工智能·算法·机器学习