LeetCode hoot 100 -- 和为K的子数组

本题取自LeetCode hoot 100 题号560 和为K的子数组

一 题目概述

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

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

二 思路解析

题中提到子数组数连续序列,我们容易想到利用'前缀和'。'前缀和'顾名思义,前n个元素的和。观察其特性不难发现,原数组中任意一个连续序列的和都可以由某两个前缀和相减得到。示意图如下:

经过前缀和的转换,此题是否就可以简化的看成"两数之和"的问题了?也就是说遍历所有前缀和curr_sum,判断该curr_sum之前的前缀和中是否出现了值curr_sum。值得一提,同一个值可能对应多个前缀和,如:1,1,0,又如:1,-1,1 。这样也会使得和为K的数组结果变多。所以在此我们不妨利用unordered_map结构,既能够做到快速查找,又能够记录某一个值出现的次数。

三 代码解析

cpp 复制代码
// LeetCode 模型
class Solution {
public:
    // 传入数组,和K值
    int subarraySum(vector<int>& nums, int k) {
        // 利用unordered_map结构,记录前缀和及其出现的次数
        unordered_map<int, int>hash;
        // 注意hash[0]=1(关键)处理当某前缀和就等于K时的情况
        hash[0] = 1;
        int curr_sum = 0;// 当前的前缀和
        int res = 0;// 结果次数
    
        for (int num : nums)
        {
            // curr_sum记录目前的前缀和
            curr_sum += num;
            int target = curr_sum - k;
            if (hash.find(target) != hash.end())
            {
                res += hash[target];
            }
            // hash记录在此前缀和之前 的前缀和出现的次数
            hash[curr_sum]++;
        }
        return res;
    }
};

以上就是本文所有内容了。可以看到封面刷题数字由'12'变为'13'了,大家可以一起打卡保持'每日一题'的习惯。最后感谢观看。

相关推荐
To_OC8 分钟前
手写快排次次翻车?别死背快排模板了,这才是面试官想听的底层逻辑
javascript·算法·排序算法
饼干哥哥1 小时前
Reddit VOC调研太慢?搭一个AI专家团队半小时洞察任何品类|以猫用饮水机为例
人工智能·算法·ai编程
地平线开发者2 小时前
Transformer模型部署之性能优化指南
算法
地平线开发者2 小时前
人在途中:从“编译失败”到“模型可落地”——CUDA 自定义算子
算法·自动驾驶
半个落月5 小时前
从递归到快速排序:用 JavaScript 把分治思想讲明白
javascript·算法·面试
小月土星6 小时前
JavaScript 快速排序:从 pivot、双指针到分治思想
javascript·算法·面试
小月土星6 小时前
JavaScript 递归入门:从 1 到 n 求和,再到数组扁平化
javascript·算法·面试
To_OC1 天前
LC 1 两数之和:面试第一道必考题,暴力解法直接被面试官 pass
javascript·算法·leetcode
鱼鱼不愚与1 天前
《原来如此 | 第01期:为什么导航软件能预测红绿灯倒计时?》
算法