Pagini recente » Cod sursa (job #2640640) | Cod sursa (job #1577853) | Cod sursa (job #1483414) | Cod sursa (job #141431) | Cod sursa (job #1453570)
#include <cstdio>
#include <iostream>
#include <vector>
using namespace std;
int main() {
freopen("divk.in", "r", stdin);
freopen("divk.out", "w", stdout);
ios_base::sync_with_stdio(false);
cin.tie(0);
int n, k, a, b;
cin >> n >> k >> a >> b;
vector<int> v(n + 1), dp(k);
for (int i = 1; i <= n; i++) {
int aux;
cin >> aux;
v[i] = (v[i - 1] + aux) % k;
}
long long ans = 0;
for (int i = 1; i <= n; i++) {
if (i >= a) {
dp[v[i - a]]++;
}
if (i > b) {
dp[v[i - b - 1]]--;
}
ans += dp[v[i]];
}
cout << ans;
return 0;
}