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

        }
    }
相关推荐
Storynone2 小时前
【Day】LeetCode:134. 加油站,135. 分发糖果,860. 柠檬水找零,406. 根据身高重建队列
python·算法·leetcode
G探险者2 小时前
DDD开发模式说明
java·运维·数据库
Amour恋空2 小时前
SpringBoot使用SpringAi完成简单智能助手
java·spring boot·后端
jing-ya2 小时前
day52 图论part4
数据结构·算法·图论
tankeven2 小时前
最短路径问题00:dijkstra算法
c++·算法
lang201509282 小时前
18 Byte Buddy 进阶:揭秘方法委托中的“歧义解析”机制
java·byte buddy
式5162 小时前
CUDA编程学习(五)线程模型定义、矩阵相加
学习·算法·矩阵
SimonKing2 小时前
Spring Boot 动态多数据源:核心思路与关键考量
java·后端·程序员
C蔡博士2 小时前
大数乘法的算法演进:从小学方法到 Karatsuba
算法·大数乘法·分治思想