【前缀合】Leetcode 和为k的子数组

题目解析

560. 和为 K 的子数组


算法讲解

前面滑动窗口里面有一道题和这个题很相似,它是求出和为k的最短子数组的长度,但是这道题不能使用滑动窗口,因为虽然找到一段子数组的和等于k,但是这道题里面存在0和负数,可能这一段区间里面还有一段子数组也等于k
因此需要使用前缀和算法,我们求出以i位置为结尾的前缀和,在这一段区间中寻找有没有前缀和 - k的区间

cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        unordered_map<int, int>Hash;
        int sum = 0;
        int ret = 0;
        Hash[0]++;
        for(auto& n : nums)
        {
            sum += n;  //此处计算的就是以i位置为结尾的前缀和
            if(Hash.count(sum - k))ret += Hash[sum - k];  //寻找这一段区间有没出现sum - k)
            Hash[sum]++;
        }
        return ret;
    }
};

相关推荐
jiunian_cn18 小时前
【Redis】hash数据类型相关指令
数据库·redis·哈希算法
_不会dp不改名_19 小时前
leetcode_3010 将数组分成最小总代价的子数组 I
算法·leetcode·职场和发展
lingggggaaaa1 天前
安全工具篇&Go魔改二开&Fscan扫描&FRP代理&特征消除&新增扩展&打乱HASH
学习·安全·web安全·网络安全·golang·哈希算法
Tisfy1 天前
LeetCode 3637.三段式数组 I:一次遍历(三种实现)
算法·leetcode·题解·模拟·数组·遍历·moines
遨游xyz1 天前
数据结构-哈希表
算法·哈希算法
期末考复习中,蓝桥杯都没时间学了1 天前
力扣刷题15
算法·leetcode·职场和发展
im_AMBER1 天前
Leetcode 111 两数相加
javascript·笔记·学习·算法·leetcode
TracyCoder1231 天前
LeetCode Hot100(21/100)——234. 回文链表
算法·leetcode·链表
可涵不会debug1 天前
Redis魔法学院——第四课:哈希(Hash)深度解析:Field-Value 层级结构、原子性操作与内部编码优化
数据库·redis·算法·缓存·哈希算法
@––––––1 天前
力扣hot100—系列1
算法·leetcode·职场和发展