Pagini recente » Cod sursa (job #1409982) | Cod sursa (job #1520476) | Cod sursa (job #1551878) | Cod sursa (job #2742854) | Cod sursa (job #1574885)
#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 = a; 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]];
if(i-b < 0 && s[i] == 0)
sum += 1;
}
printf("%lld\n", sum);
return 0;
}