Pagini recente » Cod sursa (job #456470) | Cod sursa (job #3267189) | Cod sursa (job #2492585) | Cod sursa (job #2980596) | Cod sursa (job #1561237)
#include <cstdio>
#include <vector>
#define MAX 100000
using namespace std;
int vc[MAX+1], v[500001];
int main()
{
freopen("divk.in", "r", stdin);
freopen("divk.out", "w", stdout);
int n, k,a,b, i, s=0, x;
long long r=0;
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=a;i<=n;i++)
{
vc[v[i-a]]++;
r=r+vc[v[i]];
if(i>b)
vc[v[i-b-1]]--;
}
printf("%lld", r);
return 0;
}