解题思路:
注意事项:
参考代码:
#include<stdio.h>
int main(){
int n,k,i;
scanf("%d%d",&n,&k);
int a[n],sum[n]; //这里的数组是用变量定义的,于是赋值必须用循环
long long int ans=0,b[k]; //数组b存储各剩余类个数,当k=1,数组b不是long long测试过不去
for(i=0;i<n;i++){
scanf("%d",&a[i]);
}
for(i=0;i<k;i++)
b[i]=0;
sum[0]=a[0];
b[a[0]%k]++;
for(i=1;i<n;i++){
sum[i]=(sum[i-1]+a[i])%k;
b[sum[i]]++;
}
for(i=0;i<k;i++){
ans+=b[i]*(b[i]-1)/2;
}
ans+=b[0];
printf("%lld",ans);
return 0;
}
0.0分
0 人评分
输出九九乘法表 (C语言代码)浏览:582 |
C语言程序设计教程(第三版)课后习题3.7 (C语言代码)浏览:607 |
C语言训练-最大数问题 (C语言代码)浏览:648 |
C语言程序设计教程(第三版)课后习题10.4 (C语言代码)浏览:702 |
上车人数 (C语言代码)浏览:816 |
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:724 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:669 |
输出正反三角形 (C语言代码)浏览:859 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1685 |
简单的for循环浏览:1498 |