Pagini recente » Cod sursa (job #2169067) | Cod sursa (job #403284) | Cod sursa (job #104862) | Cod sursa (job #1872088) | Cod sursa (job #467351)
Cod sursa(job #467351)
#include<fstream>
using namespace std;
int a, b, n, k, s[500001], v[500001];
long long tot;
int main()
{
ifstream fin("divk.in");
ofstream fout("divk.out");
fin >> n >> k >> a >> b;
for (int i = 1, aux; i <= n; ++i)
{
fin >> aux;
s[i] = (s[i - 1] + aux) % k;
//v[r] = de cate ori apare restul 'r' in s[i - b + 1]...s[i - a + 1]
if (i - b - 1 >= 0) --v[s[i - b - 1]];
if (i - a >= 0) ++v[s[i - a]];
tot += v[s[i]];
}
fout << tot;
return 0;
}