LeetCode Hot Code —— 和为K的子数组

给你一个整数数组 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

    class Solution {
    public:
    // 前缀和
    int subarraySum(vector<int>& nums, int k)
    {
    int ans = 0;
    vector<int> arr(nums.size(), 0);
    arr[0] = nums[0];
    map<int, int> tu;
    for (int i = 1; i < nums.size(); i++)
    {
    arr[i] = arr[i - 1] + nums[i];
    }
    for (int i = 0; i < nums.size(); i++)
    {
    if (arr[i] == k)
    {
    ans++;
    }
    int num = arr[i] - k;
    if (tu.count(num) == 1)
    {
    ans += tu[num];
    }
    tu[arr[i]]++;

    复制代码
      }
      return ans;

    }
    };

相关推荐
不爱吃炸鸡柳3 小时前
数据结构精讲:树 → 二叉树 → 堆 从入门到实战
开发语言·数据结构
Aurorar0rua3 小时前
CS50 x 2024 Notes C - 05
java·c语言·数据结构
6Hzlia4 小时前
【Hot 100 刷题计划】 LeetCode 739. 每日温度 | C++ 逆序单调栈
c++·算法·leetcode
良木生香5 小时前
【C++初阶】:STL——String从入门到应用完全指南(1)
c语言·开发语言·数据结构·c++·算法
XWalnut5 小时前
LeetCode刷题 day16
数据结构·算法·leetcode·链表·动态规划
寒秋花开曾相惜5 小时前
(学习笔记)4.1 Y86-64指令集体系结构(4.1.4 Y86-64异常&4.1.5 Y86-64程序)
开发语言·jvm·数据结构·笔记·学习
foundbug9997 小时前
基于混合整数规划的电池容量优化 - MATLAB实现
数据结构·算法·matlab
自我意识的多元宇宙7 小时前
树、森林——树与二叉树的应用(哈夫曼树的构造)
数据结构
memcpy08 小时前
LeetCode 2452. 距离字典两次编辑以内的单词【暴力;字典树】中等
算法·leetcode·职场和发展