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