Pagini recente » Cod sursa (job #2922810) | Cod sursa (job #961327) | Cod sursa (job #2493547) | Cod sursa (job #2161916) | Cod sursa (job #1397892)
#include <iostream>
#include <cstdio>
using namespace std;
#define maxN 500011
#define maxK 100011
long n,k,a,b,i;
long v[maxN];
long cnt[maxK];
long long ans;
int main()
{
freopen("divk.in","r",stdin);
freopen("divk.out","w",stdout);
scanf("%ld%ld%ld%ld",&n,&k,&a,&b);
for(i=1;i<=n;i++){
scanf("%ld",&v[i]);
v[i] += v[i-1];
v[i] %= k;
}
cnt[0]++;
for(i=1;i<=a;i++) cnt[v[i]]++;
for(i=a+1;i<=n;i++){
if(i-b-1>=0) cnt[v[i-b-1]]--;
ans += cnt[v[i]];
cnt[v[i-a]]++;
}
printf("%lld",ans);
return 0;
}