力扣 hot100 和为K的子数组 哈希&前缀和

题目链接:

560. 和为 K 的子数组 - 力扣(LeetCode)

题目描述:

给你一个整数数组 nums 和一个整数 k ,请你统计并返回 该数组中和为 k的子数组的个数

子数组是数组中元素的连续非空序列。

示例 1:

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

示例 2:

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

提示:

  • 1 <= nums.length <= 2 * 104
  • -1000 <= nums[i] <= 1000
  • -107 <= k <= 107

我的思路:

我们可以创建一个哈希表来记录每一个前缀和的出现次数,然后通过当前前缀和来减k得到数和哈希表的数来对比,如果哈希表也有这个数,说明之前有前缀和可以和当前的前缀和相减可以得到k,所以答案加上当前前缀和-k得到的哈希映射的个数,也就是numQ - numO = k中numO的个数

我的代码:

java 复制代码
class Solution {
        public int subarraySum(int[] nums, int k) {

            HashMap<Integer, Integer> integerIntegerHashMap = new HashMap<>();
            integerIntegerHashMap.put(0,1);
            int ans=0;
            int numQ=0;

            for (int num : nums) {

                numQ += num;

                if (integerIntegerHashMap.containsKey(numQ - k)) {
                    ans += integerIntegerHashMap.get(numQ - k);
                }

                integerIntegerHashMap.put(numQ, integerIntegerHashMap.getOrDefault(numQ, 0) + 1);

            }

            return ans;

        }
    }
相关推荐
澈2071 分钟前
C++面向对象:类与对象核心解析
c++·算法
用户690673881924 分钟前
基于无人机的单目测距系统,平均误差仅2.12%
算法
Carsene13 分钟前
第一章:为什么我们需要“类型安全”的 SQL DSL 框架?
java·sql
wyu7296115 分钟前
Spring MVC 学习笔记:配置、注解、RESTful、JSON、拦截器、SSM整合、文件上传下载
java
6Hzlia17 分钟前
【Hot 100 刷题计划】 LeetCode 141. 环形链表 | C++ 哈希表直觉解法
c++·leetcode·链表
dinl_vin20 分钟前
LangChain 系列·(四):RAG 基础——给大模型装上“外脑“
人工智能·算法·langchain
Mr_pyx26 分钟前
Java 注解(Annotation)详解:从基础到 APT 实战
java·数据库·sqlserver
码完就睡41 分钟前
数据结构——哈希表原理与C语言实现总结
数据结构·散列表
探物 AI1 小时前
【感知·医学分割】当 YOLOv11 杀入医学赛道:先检测后分割的级联架构
算法·yolo·计算机视觉·架构
MegaDataFlowers1 小时前
调用Service层操作数据
java·开发语言