力扣 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;

        }
    }
相关推荐
star-yp1 分钟前
vibe coding 博客管理系统
java·spring boot·spring·ai·ai编程
小江的记录本3 分钟前
【JEECG Boot】JEECG Boot 系统性知识体系全方位结构化总结
java·前端·spring boot·后端·python·spring·spring cloud
Mr.wangh4 分钟前
Spring原理(Bean的生命周期)
java·前端·spring
派大星酷7 分钟前
Java 多线程创建方式
java·开发语言·多线程
小肝一下2 小时前
每日两道力扣,day5
数据结构·c++·算法·leetcode·职场和发展·hot100
jiang_changsheng2 小时前
亚马逊的2026年最新算法变革自然流量分发机制“文本匹配”到“多模态意图理解”的范式革命
大数据·算法·推荐算法
OOJO7 小时前
c++---list介绍
c语言·开发语言·数据结构·c++·算法·list
别或许8 小时前
1、高数----函数极限与连续(知识总结)
算法
派大星~课堂8 小时前
【力扣-142. 环形链表2 ✨】Python笔记
python·leetcode·链表
田梓燊8 小时前
code 560
数据结构·算法·哈希算法