Pagini recente » Cod sursa (job #3133858) | Cod sursa (job #2691596) | Cod sursa (job #3231084) | Cod sursa (job #3149539) | Cod sursa (job #1398450)
#include <cstdio>
using namespace std;
int n, k, a, b, v[500010], cnt[100010], i, s, x;
int main(){
freopen("divk.in", "r", stdin);
freopen("divk.out", "w", stdout);
scanf("%d %d %d %d", &n, &k, &a, &b);
for(i=1; i<=n; i++)
{
scanf("%d", &x);
v[i]=(v[i-1]+x)%k;
}
for(i=1; i<a; i++)
cnt[ v[i] ]++;
for(i=a; i<=b; i++)
{
s+=cnt[ v[i] ];
cnt[ v[i] ]++;
}
for(i=b+1; i<=n; i++)
{
cnt[ v[i-b] ]--;
s+=cnt[ v[i] ];
cnt[ v[i] ]++;
}
printf("%d\n", s);
return 0;
}