Cod sursa(job #1574888)
Utilizator | Data | 20 ianuarie 2016 22:03:50 | |
---|---|---|---|
Problema | Divk | Scor | 40 |
Compilator | cpp | Status | done |
Runda | Arhiva de probleme | Marime | 0.56 kb |
#include <cstdio>
using namespace std;
const int nmx = 500002;
int n,k,a,b,v[nmx],s[nmx],nr;
long long sum;
int main(){
freopen("divk.in", "r", stdin);
freopen("divk.out", "w", stdout);
scanf("%d %d %d %d", &n, &k, &a, &b);
for(int i = 1; i <= n; ++i){
scanf("%d", &nr);
s[i] = (s[i-1] + nr) % k;
}
for(int i = 1; i <= n; ++i){
if(i-a+1 >= 0)
++ v[s[i-a+1]];
if(i-b >= 0)
-- v[s[i-b]];
sum += v[s[i]];
}
printf("%lld\n", sum);
return 0;
}