算法---前缀和练习-2(和为k的子数组)

和为k的子数组

  • [1. 题目解析](#1. 题目解析)
  • [2. 讲解算法原理](#2. 讲解算法原理)
  • [3. 编写代码](#3. 编写代码)

1. 题目解析

题目地址点这里

2. 讲解算法原理

  1. 创建一个无序映射(哈希表) hash,用于统计前缀和的出现次数。初始时,将前缀和为 0 的次数设为 1,表示从数组开头到当前位置的累计和为 0 的子数组个数为 1。

  2. 初始化两个变量 sum 和 ret,分别表示当前的前缀和和满足条件的子数组个数,初始时都设为 0。

  3. 遍历数组 nums 的每个元素 e:

  4. 将 e 加到 sum 中,更新当前的前缀和。

  5. 检查 hash 中是否存在前缀和为 sum - k 的记录,即是否存在一个位置 i,使得从位置 i 到当前位置的子数组的和为 k。如果存在,将 hash[sum - k] 的值累加到 ret 中,表示找到了满足条件的子数组。

  6. 更新 hash[sum],将前缀和 sum 的出现次数加 1。

  7. 完成遍历后,返回 ret,即满足条件的子数组的个数。


3. 编写代码

cpp 复制代码
class Solution {
public:
    int subarraySum(vector<int>& nums, int k) {
        unordered_map<int,int> hash;//统计前缀和次数
        hash[0]=1;
        int sum=0,ret=0;
        for(auto e:nums)
        {
            sum+=e;
            if(hash.count(sum-k)) ret+=hash[sum-k];
            hash[sum]++;
        }
        return ret;
    }
};
相关推荐
ゞ 正在缓冲99%…3 分钟前
2025.9.24华为软开
java·算法·华为
十五年专注C++开发7 分钟前
sigslot: 一个轻量级实现观察者模式的C++开源库
c++·观察者模式·开源
Dev7z7 分钟前
基于MATLAB实现SVM和集成特征的水稻病害图像识别系统
算法·机器学习·支持向量机
AI科技星8 分钟前
时空的几何之歌:论统一场论动量公式 P = m(C - V) 的完备重构、量化哲学诠释与终极验证
数据结构·人工智能·算法·机器学习·计算机视觉·重构
千千道8 分钟前
QT上位机作为FTP客户端上传多文件
c++·qt
屿筱10 分钟前
vscode 关于C/C++的环境配置
c++·ide·vscode
大千AI助手11 分钟前
基于实例的学习:最近邻算法及其现代演进
人工智能·算法·机器学习·近邻算法·knn·大千ai助手·基于实例的学习
程序喵大人14 分钟前
C++ MCP 服务器实现
开发语言·c++·项目·mcp服务器
小尧嵌入式15 分钟前
QT软件开发知识点流程及文本转语音工具
开发语言·c++·qt
程序员-King.17 分钟前
day108—同向双指针—乘积小于K的子数组(LeetCode-713)
算法·leetcode·双指针