热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

[SwiftWeeklyContest119]LeetCode974.和可被K整除的子数组|SubarraySumsDivisiblebyK

GivenanarrayAofintegers,returnthenumberof(contiguous,non-empty)subarraysthathaveasum

Given an array A of integers, return the number of (contiguous, non-empty) subarrays that have a sum divisible by K.

Example 1:

Input: A = [4,5,0,-2,-3,1], K = 5 Output: 7 Explanation: There are 7 subarrays with a sum divisible by K = 5: [4, 5, 0, -2, -3, 1], [5], [5, 0], [5, 0, -2, -3], [0], [0, -2, -3], [-2, -3] 

Note:

  1. 1 <= A.length <= 30000
  2. -10000 <= A[i] <= 10000
  3. 2 <= K <= 10000

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

示例:

输入:A = [4,5,0,-2,-3,1], K = 5
输出:7
解释:
有 7 个子数组满足其元素之和可被 K = 5 整除:
[4, 5, 0, -2, -3, 1], [5], [5, 0], [5, 0, -2, -3], [0], [0, -2, -3], [-2, -3] 

提示:

  1. 1 <= A.length <= 30000
  2. -10000 <= A[i] <= 10000
  3. 2 <= K <= 10000

 368ms 

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3         var n = A.count
 4         var f:[Int] = [Int](repeating:0,count:K)
 5         f[0] = 1
 6         var x:Int = 0 
 7         for v in A
 8         {
 9             x += v
10             x %= K
11             if x <0
12             {
13                 x += K
14             }
15             f[x] += 1
16         }
17         var ret:Int = 0
18         for i in  0..<K
19         {
20             ret += f[i]*(f[i]-1)/2
21         }
22         return ret
23     }
24 }

372ms

 

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3      
 4         var res = 0
 5         var prefixArr = Array(repeating:0, count:K)
 6         var prefix = 0
 7         prefixArr[0] = 1
 8         
 9         for num in A {
10             prefix = (prefix + num % K + K) % K
11             res += prefixArr[prefix]
12             prefixArr[prefix] += 1
13         }
14         
15         return res
16     }
17 }

392ms

 1 class Solution {
 2     
 3     func subarraysDivByK(_ values: [Int], _ k: Int) -> Int {
 4         var reminderCount = [Int: Int]() 
 5         var sum = 0
 6 
 7         for i in 0..<values.count {
 8             sum += values[i]
 9             let reminder = (sum % k + k) % k
10             reminderCount[reminder, default: 0] += 1
11         }
12 
13         var subArraysCount = 0
14         subArraysCount += reminderCount[0] ?? 0
15 
16         for key in reminderCount.keys {
17             if let count = reminderCount[key], count > 0 {
18                 subArraysCount += (count * (count - 1))/2
19             }
20         }
21 
22         return subArraysCount
23     }    
24 }

400ms

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3         let N = A.count
 4         var P = [Int](repeating: 0, count: N+1)
 5         for i in 0..<N {
 6             P[i+1] = P[i] + A[i]
 7         }
 8 
 9         var count = [Int](repeating: 0, count: K)
10         for x in P {
11             count[(x%K + K)%K] = count[(x%K + K)%K] + 1
12         }
13 
14         var ans = 0;
15         for v in count {
16             ans += v*(v-1)/2
17         }
18         return ans
19     }
20 }

404ms

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3         var mod = [Int:Int]()
 4         var result = 0
 5         var sum = 0
 6         mod[0] = 1
 7         for num in A{
 8             sum = (sum + num)%K
 9             if sum <0{
10                 sum = sum + K
11             }
12             
13             if let value = mod[sum]{
14                 result += value
15                 mod[sum] = value + 1
16             }else{
17                 mod[sum] = 1
18             }
19         }
20         
21         return result
22     }
23 }

408ms

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3         var sums: [Int] = Array(repeating: 0, count: K)
 4         var sum: Int = 0
 5         for (index, a) in A.enumerated() {
 6             sum += a
 7             sum %= K
 8             if sum <0 { sum += K }
 9             sums[sum] += 1
10         }
11         var res = sums[0]
12         for s in sums {
13             if s > 1 {
14                 res += s*(s-1)/2
15             }
16         }
17         
18         return res
19     }
20 }

452ms

 1 class Solution {
 2     func subarraysDivByK(_ A: [Int], _ K: Int) -> Int {
 3         var counts = [0:1]
 4         
 5         var current = 0
 6         var result = 0
 7         for a in A {
 8             current = (current + a) % K
 9             while current <0 {
10                 current += K
11             }
12             result += counts[current, default:0]
13             counts[current] = counts[current, default:0] + 1
14         }
15         return result
16     }
17 }

 


推荐阅读
  • [大整数乘法] java代码实现
    本文介绍了使用java代码实现大整数乘法的过程,同时也涉及到大整数加法和大整数减法的计算方法。通过分治算法来提高计算效率,并对算法的时间复杂度进行了研究。详细代码实现请参考文章链接。 ... [详细]
  • 前景:当UI一个查询条件为多项选择,或录入多个条件的时候,比如查询所有名称里面包含以下动态条件,需要模糊查询里面每一项时比如是这样一个数组条件:newstring[]{兴业银行, ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 图解redis的持久化存储机制RDB和AOF的原理和优缺点
    本文通过图解的方式介绍了redis的持久化存储机制RDB和AOF的原理和优缺点。RDB是将redis内存中的数据保存为快照文件,恢复速度较快但不支持拉链式快照。AOF是将操作日志保存到磁盘,实时存储数据但恢复速度较慢。文章详细分析了两种机制的优缺点,帮助读者更好地理解redis的持久化存储策略。 ... [详细]
  • 本文介绍了Perl的测试框架Test::Base,它是一个数据驱动的测试框架,可以自动进行单元测试,省去手工编写测试程序的麻烦。与Test::More完全兼容,使用方法简单。以plural函数为例,展示了Test::Base的使用方法。 ... [详细]
  • 判断数组是否全为0_连续子数组的最大和的解题思路及代码方法一_动态规划
    本文介绍了判断数组是否全为0以及求解连续子数组的最大和的解题思路及代码方法一,即动态规划。通过动态规划的方法,可以找出连续子数组的最大和,具体思路是尽量选择正数的部分,遇到负数则不选择进去,遇到正数则保留并继续考察。本文给出了状态定义和状态转移方程,并提供了具体的代码实现。 ... [详细]
  • 本文介绍了一个在线急等问题解决方法,即如何统计数据库中某个字段下的所有数据,并将结果显示在文本框里。作者提到了自己是一个菜鸟,希望能够得到帮助。作者使用的是ACCESS数据库,并且给出了一个例子,希望得到的结果是560。作者还提到自己已经尝试了使用"select sum(字段2) from 表名"的语句,得到的结果是650,但不知道如何得到560。希望能够得到解决方案。 ... [详细]
  • 个人学习使用:谨慎参考1Client类importcom.thoughtworks.gauge.Step;importcom.thoughtworks.gauge.T ... [详细]
  • HDFS2.x新特性
    一、集群间数据拷贝scp实现两个远程主机之间的文件复制scp-rhello.txtroothadoop103:useratguiguhello.txt推pushscp-rr ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 也就是|小窗_卷积的特征提取与参数计算
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了卷积的特征提取与参数计算相关的知识,希望对你有一定的参考价值。Dense和Conv2D根本区别在于,Den ... [详细]
  • ALTERTABLE通过更改、添加、除去列和约束,或者通过启用或禁用约束和触发器来更改表的定义。语法ALTERTABLEtable{[ALTERCOLUMNcolu ... [详细]
  • 3.223.28周学习总结中的贪心作业收获及困惑
    本文是对3.223.28周学习总结中的贪心作业进行总结,作者在解题过程中参考了他人的代码,但前提是要先理解题目并有解题思路。作者分享了自己在贪心作业中的收获,同时提到了一道让他困惑的题目,即input details部分引发的疑惑。 ... [详细]
  • 本文详细介绍了如何使用MySQL来显示SQL语句的执行时间,并通过MySQL Query Profiler获取CPU和内存使用量以及系统锁和表锁的时间。同时介绍了效能分析的三种方法:瓶颈分析、工作负载分析和基于比率的分析。 ... [详细]
  • This article discusses the efficiency of using char str[] and char *str and whether there is any reason to prefer one over the other. It explains the difference between the two and provides an example to illustrate their usage. ... [详细]
author-avatar
美竹
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有