Pagini recente » Cod sursa (job #849063) | Cod sursa (job #1307145) | Cod sursa (job #1651421) | Rating Lungu Mihai (Lungumihai) | Cod sursa (job #1852379)
#include <unordered_map>
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("divk.in");
ofstream out("divk.out");
const int maxn = 500005;
unordered_map <int, int> fr;
int v[maxn];
int main()
{
int n, k, a, b;
in >> n >> k >> a >> b;
for(int i = 1; i <= n; i++)
{
in >> v[i];
v[i] = (v[i - 1] + v[i]) % k;
}
int lg = 0;
int T = 0;
for(int i = 1; i <= n; i++)
{
fr[v[i]]++;
lg++;
if(lg > b)
{
lg = b;
fr[v[i - b]]--;
}
if(lg >= a)
T = T + fr[v[i]] - 1;
}
out << T << "\n";
return 0;
}