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

相关推荐
Lumbrologist几秒前
【C++】零基础入门 · 第 17 节:多线程编程基础
java·c++·算法
轻闲一号机27 分钟前
【语音】笔记
前端·笔记·算法
aWty_39 分钟前
实分析入门(12)--可测函数
学习·数学·算法·实变函数
海砥装备HardAus1 小时前
无人机姿态解算中「重力矢量观测退化」机理与动态补偿技术
算法·无人机·飞控
广州灵眸科技有限公司1 小时前
瑞芯微RV1126B开发板(EASY-EAI-PI2) 开发套件组装上电
网络·数据库·人工智能·算法·飞书
SuperHeroWu71 小时前
【算法】强化学习中奖励和损失函数的关系
算法·环境·强化学习·损失函数·奖励
voidmort1 小时前
9. 微调(Fine-tuning)的数学原理
人工智能·算法·机器学习
晚风吹红霞1 小时前
C++ stack 和 queue 完全指南:适配器模式与双端队列的奥秘
c++·算法·适配器模式
casual~2 小时前
十六届蓝桥杯国赛个人题解
经验分享·学习·算法·蓝桥杯
方也_arkling2 小时前
【Java-Day18】API篇-Arrays
java·算法·排序算法