560. 和为 K 的子数组

记录力扣学习~

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

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

示例 1:

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

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

公式更可观:当前pre = 当前遍历到的数字num[i] + 前面累计的前缀和。如果当前pre - k存在,那么这段 pre - k 构成的子数组一定是连续的因为哈希表存储的是连续的前缀和,又根据最开始的公式那么就可以知道,和为k的连续子数组 + nums[i] + (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;
    }
};
相关推荐
小年糕是糕手2 小时前
【C++】模板初阶
java·开发语言·javascript·数据结构·c++·算法·leetcode
AndrewHZ3 小时前
【遥感图像入门】遥感图像专用去噪算法:核心方案与实战(PyTorch代码)
pytorch·算法·计算机视觉·cv·遥感图像·高分辨率·去噪算法
前端小L4 小时前
回溯算法专题(八):精细化切割——还原合法的「IP 地址」
数据结构·算法
Hcoco_me10 小时前
大模型面试题17:PCA算法详解及入门实操
算法
跨境卫士苏苏10 小时前
亚马逊AI广告革命:告别“猜心”,迎接“共创”时代
大数据·人工智能·算法·亚马逊·防关联
程序员小白条11 小时前
0经验如何找实习?
java·开发语言·数据结构·数据库·链表
云雾J视界11 小时前
当算法试图解决一切:技术解决方案主义的诱惑与陷阱
算法·google·bert·transformer·attention·算法治理
Xの哲學11 小时前
Linux Miscdevice深度剖析:从原理到实战的完整指南
linux·服务器·算法·架构·边缘计算
夏乌_Wx12 小时前
练题100天——DAY23:存在重复元素Ⅰ Ⅱ+两数之和
数据结构·算法·leetcode