560. 和为 K 的子数组

记录力扣学习~

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k的子数组的个数

子数组是数组中元素的连续非空序列。

示例 1:

复制代码
输入:nums = [1,1,1], k = 2
输出:2

思路:前缀和 + 哈希表记录前缀出现次数。通过遍历对数组进行累加得到 pre,在累加的过程中对前缀和出现的次数进行记录,然后对每次累加的结果判断是否存在一个前缀的和,使得 pre - k 等于这个前缀和。如果存在,那么说明一定存在一个连续的子数组和为k。因为这个前缀和是连续子数组组成的,且当前的前缀和 pre 也是由前面所有的数字累加起来的所以就一定存在一个连续子数组和为k。

公式更可观:当前pre = 当前遍历到的数字numi + 前面累计的前缀和。如果当前pre - k存在,那么这段 pre - k 构成的子数组一定是连续的因为哈希表存储的是连续的前缀和,又根据最开始的公式那么就可以知道,和为k的连续子数组 + numsi + (pre - k)所处的连续子数组 = 当前的pre。因为你只有连续的子数组 + 和为k的连续子数组才等于当前的前缀和。

力扣官方代码实现:

cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        unordered_map<int, int> mp;
        mp[0] = 1;
        int count = 0, pre = 0;
        for (auto& x:nums) {
            pre += x;
            if (mp.find(pre - k) != mp.end()) {
                count += mp[pre - k];
            }
            mp[pre]++;
        }
        return count;
    }
};
相关推荐
JieE2121 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack209 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树11 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术1 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050731 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架