当前位置: 首页 > news >正文

和为K的子数组

题目:

使用前缀和的方法可以解决这个问题,因为我们需要找到和为k的连续子数组的个数。通过计算前缀和,我们可以将问题转化为求解两个前缀和之差等于k的情况。
假设数组的前缀和数组为prefixSum,其中prefixSum[i]表示从数组起始位置到第i个位置的元素之和。那么对于任意的两个下标i和j(i < j),如果prefixSum[j] - prefixSum[i] = k,即从第i个位置到第j个位置的元素之和等于k,那么说明从第i+1个位置到第j个位置的连续子数组的和为k。
通过遍历数组,计算每个位置的前缀和,并使用一个哈希表来存储每个前缀和出现的次数。在遍历的过程中,我们检查是否存在prefixSum[j] - k的前缀和,如果存在,说明从某个位置到当前位置的连续子数组的和为k,我们将对应的次数累加到结果中。
这样,通过遍历一次数组,我们可以统计出和为k的连续子数组的个数,并且时间复杂度为O(n),其中n为数组的长度。

class Solution {
public:int subarraySum(vector<int>& nums, int k) {unordered_map<int, int> m;m[0] = 1;int pre = 0;int ans = 0;for(auto& n:nums){pre += n;if(m.count(pre - k)) ans += m[pre - k];m[pre]++;}return ans;}
};
http://www.lryc.cn/news/313233.html

相关文章:

  • Redis:java中redis的基本使用(springboot)
  • 微型计算机技术
  • mysql下载教程
  • ResponseStatusException
  • 第五十二回 戴宗二取公孙胜 李逵独劈罗真人-飞桨AI框架安装和使用示例
  • CSAPP-程序的机器级表示
  • TCP传输收发
  • OJ习题之——圆括号编码
  • Android耗电分析之Battery Historian工具使用
  • vue el-avatar 使用require提示无法找到图片
  • 深入理解 C# 中的 Task:异步编程的利器
  • YOLOv9电动车头盔佩戴检测,详细讲解模型训练
  • OpenStack之Nova
  • 虽说主业搞前端,看到如此漂亮的网页UI,也是挪不开眼呀。
  • 嵌入式学习第二十六天!(网络传输:TCP编程)
  • 【LeetCode】升级打怪之路 Day 14:二叉树的遍历
  • [Unity实战]使用NavMeshAgent做玩家移动
  • 官网:随便搞个?那不如不搞,搞不好就给公司减分了。
  • Ansible 基础入门
  • 讨论:5万官网是建站界的劳斯莱斯了吧,到了软件开发领域呢?
  • 手写分布式配置中心(三)增加实时刷新功能(短轮询)
  • 【RabbitMQ】WorkQueue
  • 国内免费好用 Chat GPT推荐
  • 基于springboot实现在线考试系统项目【项目源码+论文说明】
  • golang中go build 后读取配置文件
  • 为raspberrypi编译bpftrace调试工具
  • 分段线性化问题探析
  • 从零学算法2917
  • [HackMyVM] 靶场 Wave
  • 云渲染平台都开始涨价了?2024年性价比高的云渲染平台推荐