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'了,大家可以一起打卡保持'每日一题'的习惯。最后感谢观看。

相关推荐
算法即正义2 小时前
国家安全知识竞赛题库精讲与备赛指南
职场和发展·学习方法
_深海凉_2 小时前
LeetCode热题100-最长递增子序列
算法·leetcode·职场和发展
fengfuyao9852 小时前
MATLAB计算任意倾斜平面的太阳辐射量,包括直射、散射和反射分量
算法·matlab·平面
星马梦缘2 小时前
离散数学——图论 作战记录
算法·深度优先·图论·离散数学·生成树·哈密顿图·欧拉图
m0_743106462 小时前
【浙大&南洋理工最新综述】Feed-Forward 3D Scene Modeling(四)
深度学习·算法·计算机视觉·3d·几何学
Peregrine92 小时前
数据结构 - > 双链表
c语言·数据结构·算法
小江的记录本2 小时前
【分布式】分布式核心组件——分布式限流:固定窗口、滑动窗口、漏桶、令牌桶算法,网关层/服务层限流实现
java·分布式·后端·python·算法·安全·面试
不懂的浪漫2 小时前
一次设备映射缓存设计:用多索引 Map 把高频查询从遍历变成直接命中
java·算法·spring·缓存
apollowing2 小时前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(三十)
算法·启发式算法·web app