Pagini recente » Cod sursa (job #2476777) | Cod sursa (job #2762215) | Cod sursa (job #1213122) | Cod sursa (job #2923429) | Cod sursa (job #2249395)
#include <bits/stdc++.h>
#define ull unsigned long long
using namespace std;
FILE *f = freopen( "divk.in", "r", stdin);
FILE *g = freopen( "divk.out", "w", stdout);
int n, k, a, b;
ull v[100005], ans;
int vf[500005];
int main()
{
int x;
scanf( "%d%d%d%d", &n, &k, &a, &b );
for( int i = 1; i <= n; ++i)
{
scanf( "%d", &x );
v[i] = v[i - 1] + (ull)x;
if( i - a >= 0 )
++vf[ v[i - a] % k ];
if( i - b -1 >= 0 )
--vf[ v[i - b - 1] % k];
if( i - a >= 0)
ans += vf[ v[i] % k ];
}
printf( "%d\n", ans );
return 0;
}