Leetcode 560. 和为 K 的子数组

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

java 复制代码
class Solution {
    /**
    思路:用一个map记录前缀和,key是数值合m,value是这个m出现了n次。
    这样遍历数组,比如i从0开始,遍历到i=j时,算下下标从0-j所有元素和是多少,比如是m,
    然后算下m-k这个数值有没有出现过。
    如果出现过c次,那就是之前有c种子串和是m-k,那就对应有c种子串是k的情况;
    如果没有出现过,那就是把数值和是m的放进map,用于下次计算
     */
    public int subarraySum(int[] nums, int k) {
        Map<Integer,Integer> prefixSum=new HashMap<>();
        int res=0;
        int cnt=0;
        prefixSum.put(0,1);
        for(int i=0;i<nums.length;i++){
            cnt+=nums[i];
            // map的判断key是否存在使用containsKey,这个好好记忆一下
            if(prefixSum.containsKey(cnt-k)){
                res+=prefixSum.get(cnt-k);
            }
            if(prefixSum.get(cnt)==null){
                prefixSum.put(cnt,1);
            } else {
                prefixSum.put(cnt,prefixSum.get(cnt)+1);
            }
        }
        return res;
    }
}
相关推荐
handler01几秒前
基础算法:分治
c语言·开发语言·c++·笔记·学习·算法·深度优先
Yzzz-F5 分钟前
Problem - D2 - Codeforces [插入计数]
算法
图图的点云库5 分钟前
点云深度学习算法概述
人工智能·深度学习·算法
2501_9249526912 分钟前
设计模式在C++中的实现
开发语言·c++·算法
菜鸟小九14 分钟前
hot100(71-80)
java·数据结构·算法
不想看见40416 分钟前
Implement Queue using Stacks栈和队列--力扣101算法题解笔记
笔记·算法·leetcode
DeepModel19 分钟前
【统计检验】T检验
算法
2501_9454251531 分钟前
C++编译期字符串处理
开发语言·c++·算法
m0_7336122132 分钟前
模板编译期哈希计算
开发语言·c++·算法
ab15151736 分钟前
3.18二刷基础119、124,完成进阶52
算法