专题四_前缀和(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;
    }
};
相关推荐
雪弯了眉梢16 小时前
OpenGL(八)摄像机(Camera)
算法·图形渲染·opengl
~~李木子~~16 小时前
基于 MovieLens-100K 数据集的推荐算法设计与实现
算法·机器学习·推荐算法
Abona16 小时前
智驾空间智能、物理智能、世界模型相关的最新论文和开源算法链接
算法
sonadorje17 小时前
群的阶、元素的阶和基点G的阶详解
算法·安全
csuzhucong17 小时前
一阶鬼魔魔方
算法
夏鹏今天学习了吗17 小时前
【LeetCode热题100(73/100)】买卖股票的最佳时机
算法·leetcode·职场和发展
gaosushexiangji18 小时前
一项基于粒子图像测速(PIV)速度场反演的压力场重构技术
人工智能·算法
Voyager_418 小时前
算法学习记录17——力扣“股票系列题型”
学习·算法·leetcode
雨大王51218 小时前
汽车涂装工艺的智能化与绿色化升级:技术、案例与趋势
算法
XFF不秃头18 小时前
【力扣刷题笔记-在排序数组中查找元素的第一个和最后一个位置】
c++·笔记·算法·leetcode