Pagini recente » Cod sursa (job #1190375) | Cod sursa (job #358937) | Cod sursa (job #2774937) | Cod sursa (job #892179) | Cod sursa (job #2467450)
#include<bits/stdc++.h>
#define NAX 500005
using namespace std;
ifstream f("divk.in");
ofstream g("divk.out");
int n, a, b ,k;
long long sol;
int v[ NAX ];
int dp[ 100001 ];
int main()
{
f >> n >> k >> a >> b;
for(int i = 1 ; i <= n ; ++i)
f >> v[ i ];
for(int i = 1 ; i <= n ; ++i)
{
v[ i ] = (v[ i ] + v[ i - 1 ]) % k;
if( i >= a)
dp[ v[ i - a ] ]++;
if( i > b)
dp[ v[ i - b - 1 ] ] --;
sol += dp[ v[i] ];
}
g << sol;
return 0;
}