Pagini recente » Cod sursa (job #1084404) | Cod sursa (job #2474702) | Cod sursa (job #912175) | Cod sursa (job #1636027) | Cod sursa (job #1889054)
#include <cstdio>
using namespace std;
int n, k, a, b, v[500002], dp[100001];
long long ct;
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", &v[i]);
v[i] = (v[i] + v[i-1]) % k;
if (i > b){
dp[v[i-b-1]] --;
}
if (i >= a){
dp[v[i-a]] ++;
}
ct += dp[v[i]];
}
printf ("%lld", ct);
return 0;
}