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;

}

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

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

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

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

相关推荐
释怀不想释怀2 小时前
vue(登录,退出,浏览器本地存储机制)
前端·javascript·vue.js·ajax·html
wh_xia_jun2 小时前
vue 3极简教程草稿(未完成)
前端·javascript·vue.js
3824278272 小时前
Edge开发者工具:保留日志与禁用缓存详解
java·前端·javascript·python·selenium
java porter2 小时前
系统架构设计之单例模式(下)
开发语言·javascript·单例模式
凌乱风雨12112 小时前
从源码角度解析C++20新特性如何简化线程超时取消
前端·算法·c++20
Jim-2ha02 小时前
【平面几何】判断一个点是否在任意多边形的内部
算法
C_心欲无痕2 小时前
react - createPortal魔法传送门
javascript·vue.js·react.js
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——合并 k 个升序链表
算法·leetcode·牛客·结构与算法
前端小L3 小时前
双指针专题(五):灵活的起跳——「无重复字符的最长子串」
javascript·算法·双指针与滑动窗口