专题四_前缀和(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;
    }
};
相关推荐
xu_yule2 小时前
算法基础(数论)—费马小定理
c++·算法·裴蜀定理·欧拉定理·费马小定理·同余方程·扩展欧几里得定理
girl-07263 小时前
2025.12.28代码分析总结
算法
NAGNIP6 小时前
GPT-5.1 发布:更聪明,也更有温度的 AI
人工智能·算法
NAGNIP6 小时前
激活函数有什么用?有哪些常用的激活函数?
人工智能·算法
元亓亓亓7 小时前
LeetCode热题100--416. 分割等和子集--中等
算法·leetcode·职场和发展
BanyeBirth7 小时前
C++差分数组(二维)
开发语言·c++·算法
xu_yule8 小时前
算法基础(数论)—算法基本定理
c++·算法·算数基本定理
CoderCodingNo9 小时前
【GESP】C++五级真题(结构体排序考点) luogu-B3968 [GESP202403 五级] 成绩排序
开发语言·c++·算法
YGGP10 小时前
【Golang】LeetCode 32. 最长有效括号
算法·leetcode