【LC】560. 和为 K 的子数组

题目描述:

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k的子数组的个数。子数组是数组中元素的连续非空序列。

示例 1:

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

示例 2:

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

题解:

前缀和+哈希表

class Solution {
    public int subarraySum(int[] nums, int k) {
        int n = nums.length;
        int[] s = new int[n + 1];
        for (int i = 0; i < n; i++) {
            s[i + 1] = s[i] + nums[i];
        }
        int ans = 0;
        Map<Integer, Integer> map = new HashMap<>();
        for (int i = 0; i <= n; i++) {
            ans += map.getOrDefault(s[i] - k, 0);
            map.merge(s[i], 1, Integer :: sum);
        }
        return ans;
    }
}
相关推荐
神秘的t7 分钟前
javaEE初阶————多线程初阶(1)
java·开发语言
佳小蛙20 分钟前
Java参数值传递
java·算法·排序算法
一只鸡某27 分钟前
算法--最大公约数,最小公倍数
开发语言·c++·算法
xmh-sxh-131430 分钟前
消息中间件类型介绍
java
像污秽一样32 分钟前
AI刷题-异或编码、拼凑单词 chi
c++·算法
夕洪蚀1 小时前
Java阶段四03
java·开发语言·学习
swimxu1 小时前
[ LeetCode 75 ] 283 移动零(JavaScript)
javascript·算法·leetcode
计算机学姐1 小时前
基于SpirngBoot的家电销售管理系统
java·vue.js·spring boot·后端·mysql·tomcat·mybatis
码农爱java1 小时前
设计模式--策略模式【行为型模式】
java·设计模式·面试·策略模式·原理·23种设计模式
Kent_J_Truman2 小时前
【买二赠一——二分、贪心(有误)】
算法