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;
    }
};
相关推荐
长安er3 小时前
LeetCode215/347/295 堆相关理论与题目
java·数据结构·算法·leetcode·
元亓亓亓3 小时前
LeetCode热题100--62. 不同路径--中等
算法·leetcode·职场和发展
小白菜又菜4 小时前
Leetcode 1925. Count Square Sum Triples
算法·leetcode
粉红色回忆4 小时前
用链表实现了简单版本的malloc/free函数
数据结构·c++
登山人在路上5 小时前
Nginx三种会话保持算法对比
算法·哈希算法·散列表
写代码的小球5 小时前
C++计算器(学生版)
c++·算法
AI科技星5 小时前
张祥前统一场论宇宙大统一方程的求导验证
服务器·人工智能·科技·线性代数·算法·生活
予枫的编程笔记6 小时前
Redis 核心数据结构深度解密:从基础命令到源码架构
java·数据结构·数据库·redis·缓存·架构
wadesir6 小时前
掌握Rust并发数据结构(从零开始构建线程安全的多线程应用)
数据结构·安全·rust
Fuly10246 小时前
大模型剪枝(Pruning)技术简介
算法·机器学习·剪枝