【力扣练习题】热题100道【哈希】560. 和为 K 的子数组

import java.util.HashMap;

public class Solution {

/**

* 统计和为k的连续子数组个数

* @param nums 整数数组

* @param k 目标和

* @return 符合条件的子数组个数

*/

public int subarraySum(int[] nums, int k) {

// count:记录最终符合条件的子数组个数

int count = 0;

// pre:记录当前的前缀和(前i个元素的和)

int pre = 0;

// 哈希表:key=前缀和值,value=该前缀和出现的次数

HashMap<Integer, Integer> mp = new HashMap<>();

// 初始化:前缀和为0的情况出现1次(对应子数组从下标0开始的情况)

mp.put(0, 1);

复制代码
    // 遍历数组,计算前缀和并统计
    for (int i = 0; i < nums.length; i++) {
        // 累加当前元素,更新前缀和
        pre += nums[i];
        // 若哈希表中存在pre - k,说明存在j使得pre[i] - pre[j-1] = k,累加其出现次数
        if (mp.containsKey(pre - k)) {
            count += mp.get(pre - k);
        }
        // 将当前前缀和存入哈希表,若已存在则次数+1,否则设为1
        mp.put(pre, mp.getOrDefault(pre, 0) + 1);
    }
    // 返回结果
    return count;
}

}

import java.util.HashMap;

public class Solution {

/**

* 统计和为k的连续子数组个数

* @param nums 整数数组

* @param k 目标和

* @return 符合条件的子数组个数

*/

public int subarraySum(int[] nums, int k) {

// count:记录最终符合条件的子数组个数

int count = 0;

// pre:记录当前的前缀和(前i个元素的和)

int pre = 0;

// 哈希表:key=前缀和值,value=该前缀和出现的次数

HashMap<Integer, Integer> mp = new HashMap<>();

// 初始化:前缀和为0的情况出现1次(对应子数组从下标0开始的情况)

mp.put(0, 1);

复制代码
    // 遍历数组,计算前缀和并统计
    for (int i = 0; i < nums.length; i++) {
        // 累加当前元素,更新前缀和
        pre += nums[i];
        // 若哈希表中存在pre - k,说明存在j使得pre[i] - pre[j-1] = k,累加其出现次数
        if (mp.containsKey(pre - k)) {
            count += mp.get(pre - k);
        }
        // 将当前前缀和存入哈希表,若已存在则次数+1,否则设为1
        mp.put(pre, mp.getOrDefault(pre, 0) + 1);
    }
    // 返回结果
    return count;
}

}

复杂度分析

时间复杂度:O (n),其中 n 是数组长度。仅需遍历数组一次,哈希表的查询和插入操作均为 O (1)。

空间复杂度:O (n),哈希表最多存储 n 个不同的前缀和(极端情况如数组元素全为正数,前缀和唯一)。

相关推荐
AI应用实战 | RE2 分钟前
012、检索器(Retrievers)核心:从向量库中智能查找信息
人工智能·算法·机器学习·langchain
凤年徐3 分钟前
C++手撕红黑树:从0到200行,拿下STL map底层核心
c++·后端·算法
Thomas.Sir7 分钟前
AI 医疗之罕见病/疑难病辅助诊断系统从算法到实现【表型驱动与知识图谱推理】
人工智能·算法·ai·知识图谱
cccccc语言我来了8 分钟前
【C++---unordered_set/map底层封装】个不拘一格的集合。它不似有序集合那般循规蹈矩,而是以一种洒脱不羁的方式,将元素们随意地散落其中。每一个元素都是独一无二的。
开发语言·c++·哈希算法
tankeven29 分钟前
动态规划专题(03):区间动态规划从原理到实践(未完待续)
c++·算法·动态规划
田梓燊1 小时前
2026/4/11 leetcode 3741
数据结构·算法·leetcode
斯内科2 小时前
FFT快速傅里叶变换
算法·fft
2301_822703202 小时前
开源鸿蒙跨平台Flutter开发:幼儿疫苗全生命周期追踪系统:基于 Flutter 的免疫接种档案与状态机设计
算法·flutter·华为·开源·harmonyos·鸿蒙
贵慜_Derek2 小时前
Managed Agents 里,Harness 到底升级了什么?
人工智能·算法·架构
2301_822703202 小时前
鸿蒙flutter三方库实战——教育与学习平台:Flutter Markdown
学习·算法·flutter·华为·harmonyos·鸿蒙