博客
关于我
【LeetCode】可被K整除的子数组
阅读量:593 次
发布时间:2019-03-11

本文共 982 字,大约阅读时间需要 3 分钟。

题目

给定一个整数数组 A,返回其中元素之和可被 K 整除的(连续、非空)子数组的数目。

在这里插入图片描述

时间复杂度O(N^3)的暴力(超时)

int subarraysDivByK(vector
& A, int K) { int ans = 0; for (int i = 0; i < A.size(); i++) { for (int j = i; j < A.size(); j++) { int sum = 0; for (int k = i; k <= j; k++) { sum += A[k]; } if (sum % K==0) { ans++; } } } return ans;}

在这里插入图片描述

时间复杂度为O(N^2)的暴力(超时)

int subarraysDivByK(vector
& A, int K) { int ans = 0; for (int i = 0; i < A.size(); i++) { int CurrSum = 0; for (int j = i; j < A.size(); j++) { CurrSum += A[j]; if (CurrSum % K == 0) ans++; } } return ans; }

在这里插入图片描述

前缀和加哈希表

int subarraysDivByK(vector
& A, int K) { int sum = 0; int ans = 0; map
hash = { { 0,1} }; for (int i = 0; i < A.size(); i++) { sum += A[i]; int later = sum % K; if (hash.count(later)) { ans += hash[later]; } hash[later]++; } return ans; }

这个解法用到了同余定理,说实话 我还有点懵

等我弄懂了在更新

转载地址:http://naqtz.baihongyu.com/

你可能感兴趣的文章
Netty工作笔记0014---Buffer类型化和只读
查看>>
Netty工作笔记0020---Selectionkey在NIO体系
查看>>
Vue踩坑笔记 - 关于vue静态资源引入的问题
查看>>
Netty工作笔记0024---SelectionKey API
查看>>
Netty工作笔记0025---SocketChannel API
查看>>
Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
查看>>
Netty工作笔记0028---NIO 网络编程应用--群聊系统3--客户端编写1
查看>>
Netty工作笔记0034---Netty架构设计--线程模型
查看>>
Netty工作笔记0050---Netty核心模块1
查看>>
Netty工作笔记0057---Netty群聊系统服务端
查看>>
Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
查看>>
Netty工作笔记0063---WebSocket长连接开发2
查看>>
Netty工作笔记0070---Protobuf使用案例Codec使用
查看>>
Netty工作笔记0072---Protobuf内容小结
查看>>
Netty工作笔记0074---handler链调用机制实例1
查看>>
Netty工作笔记0077---handler链调用机制实例4
查看>>
Netty工作笔记0081---编解码器和处理器链梳理
查看>>
Netty工作笔记0083---通过自定义协议解决粘包拆包问题1
查看>>
Netty工作笔记0084---通过自定义协议解决粘包拆包问题2
查看>>
Netty工作笔记0085---TCP粘包拆包内容梳理
查看>>