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

相关推荐
Swift社区2 小时前
LeetCode 463 - 岛屿的周长
算法·leetcode·职场和发展
皮卡蛋炒饭.2 小时前
宽搜bfs与深搜dfs
算法·宽度优先
Coder_Boy_2 小时前
基于SpringAI的智能AIOps项目:部署相关容器化部署管理技术图解版
人工智能·spring boot·算法·贪心算法·aiops
王哈哈^_^2 小时前
【完整源码+数据集】道路拥塞数据集,yolo道路拥塞检测数据集 8921 张,交通拥堵识别数据集,路口拥塞识别系统实战教程
深度学习·算法·yolo·目标检测·计算机视觉·分类·毕业设计
POLITE32 小时前
Leetcode 240. 搜索二维矩阵 II JavaScript (Day 9)
javascript·leetcode·矩阵
leoufung2 小时前
LeetCode 64. Minimum Path Sum 动态规划详解
算法·leetcode·动态规划
一起养小猫2 小时前
LeetCode100天Day7-移动零与搜索插入位置
数据结构·算法·leetcode·指针
ullio2 小时前
div1+2. 2178E - Flatten or Concatenate
算法
yu_anan1112 小时前
PPO/GRPO算法在RLHF中的实现
算法