【力扣练习题】热题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 个不同的前缀和(极端情况如数组元素全为正数,前缀和唯一)。

相关推荐
Wect1 天前
LeetCode 130. 被围绕的区域:两种解法详解(BFS/DFS)
前端·算法·typescript
NAGNIP2 天前
一文搞懂深度学习中的通用逼近定理!
人工智能·算法·面试
颜酱2 天前
单调栈:从模板到实战
javascript·后端·算法
CoovallyAIHub2 天前
仿生学突破:SILD模型如何让无人机在电力线迷宫中发现“隐形威胁”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
从春晚机器人到零样本革命:YOLO26-Pose姿态估计实战指南
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
Le-DETR:省80%预训练数据,这个实时检测Transformer刷新SOTA|Georgia Tech & 北交大
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
强化学习凭什么比监督学习更聪明?RL的“聪明”并非来自算法,而是因为它学会了“挑食”
深度学习·算法·计算机视觉
CoovallyAIHub2 天前
YOLO-IOD深度解析:打破实时增量目标检测的三重知识冲突
深度学习·算法·计算机视觉
NAGNIP3 天前
轻松搞懂全连接神经网络结构!
人工智能·算法·面试
NAGNIP3 天前
一文搞懂激活函数!
算法·面试