Pagini recente » Cod sursa (job #78210) | Cod sursa (job #1813610) | Monitorul de evaluare | Cod sursa (job #244197) | Cod sursa (job #3315218)
#include <bits/stdc++.h>
using namespace std;
typedef long long i8;
int main() {
ifstream cin("divk.in");
ofstream cout("divk.out");
int n, k, a, b;
cin >> n >> k >> a >> b;
vector<int> pfx(n + 1, 0);
for (int i = 1; i <= n; i++) {
cin >> pfx[i];
pfx[i] += pfx[i - 1];
pfx[i] %= k;
}
vector<int> rest(k, 0);
i8 res = 0;
for (int i = a; i <= n; i++) {
int x = i - a;
int y = i - b;
rest[pfx[x]]++;
res += rest[pfx[i]];
if (y >= 0) {
rest[pfx[y]]--;
}
}
cout << res << "\n";
return 0;
}