Leetcode 560. 和为 K 的子数组 JavaScript (Day 5)

javascript 复制代码
var subarraySum = function(nums, k) {
    let count = 0,sum=0;
    let idx=new Map();
    for(let x of nums){
        idx.set(sum,(idx.get(sum)??0)+1);
        sum+=x;
        let j=sum-k;
        count+=idx.get(j)??0;
    }
    
    return count;

}

核心思想:前缀和+两数之和

前缀和
s0=0, si=nums0+nums1+⋯+numsi−1
注意 s 是一个长为 n+1 的数组,第一项一定是 0。最后一项的下标是 n。
设 i<j,如果 numsi 到 numsj−1 的元素和等于 k,用前缀和表示,就是
sj−si=k(两数之和等于k)

将所有的前缀和放入哈希表中,边放入边计算,就变成和两数之和一样的思想了

算法注意点:注意当我们拿到右边一个数时,需要先找左边有没有符合要求的数,再把这个数放入哈希表(给出的代码在下一次循环的开始放入哈希表,这样可以避免单独设置(0,1)),一定不能先把这个数放入哈希表后,在来找左边有没有符合要求的数

相关推荐
古城小栈8 小时前
为啥说:训练用BF16,推理用FP16
人工智能·算法·机器学习
KaMeidebaby8 小时前
卡梅德生物技术快报|蛋白 N 端测序在重组贻贝融合蛋白表征中的应用,解决原核表达序列偏移工艺难题
前端·人工智能·物联网·算法·百度
Turbo正则9 小时前
群论在AI中的应用概述
人工智能·算法·抽象代数
ysa0510309 小时前
【并查集】判环
c++·笔记·算法
Jerry9 小时前
KeetCode 44. 开发商购买土地
算法
Jerry10 小时前
KeetCode 58. 区间和
算法
anOnion10 小时前
Agentic 前端开发之 实时显示 AI Agent 终端输出
前端·javascript·人工智能
这是个栗子10 小时前
【前端性能优化】优化数据加载:用 Promise.all 从串行到并行
前端·javascript·性能优化·异步编程·前端优化·promise.all
Jerry10 小时前
LeetCode 209. 长度最小的子数组
算法
fei_sun11 小时前
黑洞路由(Null Route/空接口路由)
服务器·前端·javascript