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

前缀和-974.和可被k整除的子数组-力扣(LeetCode)

一、题目解析

1、子数组是数组中连续的部分

2、nums[-10^4,10^4],不能用滑动窗口优化

二、算法原理

解法1:暴力解法-枚举 O(N^2)

对于解法2的补充知识

1、同余定理

(a-b)/p=k……0->a%p=b%p
举例9%2=1,(2*4+1)%2=1%2,结合这个我们可以证明同余定理

证明:

(a-b)/p=k->a=b+p.k,对两边同时取余数,a%p=(b+p.k)%p=b%p

证毕

2、c++,java:[负数%正数]的结果以及修正

这里我们直接记结论,负数%正数=负数,-a%p=-a,对其进行修正,-a%p+p,最后在模上p,(-a%p+p)%p

解法2:前缀和+哈希表

我们需要找以最后位置为结尾的所有子数组,结合我们补充的知识,我们可以将问题转化

将问题转化为在[0,i-1]区间内找前缀和余数等于(sum%k+k)%k,对于哈希表unordered_map<int,int> hash,第一个int是前缀和余数,第二个int为出现的频率

细节问题:

1、前缀和插入数组的时机?

 在判断完前缀和余数是否存在后,加入前缀和余数

2、由于前缀和余数会存进哈希表中,所以可以用一个变量记录新计算的前缀和余数,没必要开一个前缀和余数数组

3、如果整个前缀和所得余数为k,则hash[0]=1

4、什么时候统计子数组数目?

通过hash.count((sum%k+k)%k),如果哈希表中存在该余数,则该余数的频率可以加入到最终结果中

三、代码示例

解法2:

class Solution {
public:int subarraysDivByK(vector<int>& nums, int k){int sum = 0,ret = 0;unordered_map<int,int> hash;hash[0] = 1;for(auto& e : nums){sum += e;if(hash.count((sum%k+k)%k)){ret += hash[(sum%k+k)%k];}hash[(sum%k+k)%k]++;}return ret;}
};

 

看到最后,如果对您有所帮助,还请点赞、收藏和关注,我们下期再见!

http://www.dtcms.com/a/304881.html

相关文章:

  • 实现视频实时马赛克
  • OpenShift AI - 将 Python 库安装到 Workbench 共享存储中
  • 【跨国数仓迁移最佳实践3】资源消耗减少50%!解析跨国数仓迁移至MaxCompute背后的性能优化技术
  • 深度学习篇---PaddleDetection模型选择
  • 《HCIA-Datacom 认证》希赛三色笔记:Vlan间三层通信过程解析
  • 用LangGraph实现聊天机器人记忆功能的深度解析
  • JVM知识点(1)
  • 通过管理工具(hgdbdeveloper)新建用户无法授权
  • 子数组和 问题汇总
  • AI应用:电路板设计
  • C++ 模板类型 <T>,对函数参数传递兼容性检查
  • 【Linux系统编程】Ext2文件系统
  • 001 Configuration结构体构造
  • 【C++篇】“内存泄露”的宝藏手段:智能指针
  • OpenCV 学习探秘之三:从图像读取到特征识别,再到机器学习等函数接口的全面实战应用与解析
  • Excel批量加密工具,一键保护多个文件
  • 【图像处理基石】如何对遥感图像进行实例分割?
  • 【RAG搭建Agent应用实战】基于检索增强生成(RAG)搭建特定场景Agent应用
  • Spring Boot 防重放攻击全面指南:原理、方案与最佳实践
  • AI产品经理手册(Ch3-5)AI Product Manager‘s Handbook学习笔记
  • 【Linux基础】find在linux中查找文件
  • Jenkins 详解
  • 准大一GIS专业新生,如何挑选电脑?
  • 【Kotlin】const 修饰的编译期常量
  • 医疗超声成像专用AFE模拟前端
  • 【CSS】盒子类型
  • Qwen3-Coder:介绍及使用 -- 超强AI编程助手
  • CSRF漏洞原理及利用
  • 镜像源加速下载
  • 编辑距离:理论基础、算法演进与跨领域应用