不难想到,连续的子序列暗示我们前缀和。
然而单纯的前缀和是 O ( n 2 ) O(n^2) O(n2)的,肯定跑不过。
那怎么办呢?
问题要求我们求区间和为k的倍数的区间个数。
显而易见,如果两个数模k是同一个数,那么他们的差模k余0。
所以我们统计前缀和为同一个数的个数,用他们组合一下都满足条件(不是排列 因为要大减小) c [ n ] [ 2 ] = n ∗ ( n − 1 ) 2 c[n][2]=\frac{n*(n-1)}{2}
不难想到,连续的子序列暗示我们前缀和。
然而单纯的前缀和是 O ( n 2 ) O(n^2) O(n2)的,肯定跑不过。
那怎么办呢?
问题要求我们求区间和为k的倍数的区间个数。
显而易见,如果两个数模k是同一个数,那么他们的差模k余0。
所以我们统计前缀和为同一个数的个数,用他们组合一下都满足条件(不是排列 因为要大减小) c [ n ] [ 2 ] = n ∗ ( n − 1 ) 2 c[n][2]=\frac{n*(n-1)}{2}