专题四_前缀和(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;
    }
};
相关推荐
Dizzy.5176 分钟前
数据结构(查找)
数据结构·学习·算法
分别努力读书3 小时前
acm培训 part 7
算法·图论
武乐乐~3 小时前
欢乐力扣:赎金信
算法·leetcode·职场和发展
'Debug3 小时前
算法从0到100之【专题一】- 双指针第一练(数组划分、数组分块)
算法
Fansv5873 小时前
深度学习-2.机械学习基础
人工智能·经验分享·python·深度学习·算法·机器学习
yatingliu20195 小时前
代码随想录算法训练营第六天| 242.有效的字母异位词 、349. 两个数组的交集、202. 快乐数 、1. 两数之和
c++·算法
uhakadotcom5 小时前
Google DeepMind最近发布了SigLIP 2
人工智能·算法·架构
三年呀5 小时前
计算机视觉之图像处理-----SIFT、SURF、FAST、ORB 特征提取算法深度解析
图像处理·python·深度学习·算法·目标检测·机器学习·计算机视觉
淡黄的Cherry6 小时前
istio实现灰度发布,A/B发布, Kiali网格可视化(二)
java·算法·istio
Onlooker1296 小时前
LC-单词搜索、分割回文串、N皇后、搜索插入位置、搜索二维矩阵
算法·leetcode