Pagini recente » Diferente pentru problema/bacterii2 intre reviziile 11 si 5 | Diferente pentru problema/bitconnect intre reviziile 25 si 48 | Borderou de evaluare (job #3162581) | Cod sursa (job #2621755) | Cod sursa (job #3202685)
#include <bits/stdc++.h>
using namespace std;
ifstream in("divk.in");
ofstream out("divk.out");
int v[500001];
int main()
{
int n,k,a,b;
in>>n>>k>>a>>b;
for(int i=1;i<=n;i++){
in>>v[i];
}
for(int i=1;i<=n;i++){
v[i]= ( v[i] + v[i-1] ) % k;
}
int cnt=0;
int st=1,dr=1;
while(st<=n){
if(v[dr]==v[st-1] && (dr-st+1) >= a && (dr-st+1)<= b ){
cnt++;
}
dr++;
if(dr>n) {
st++;
dr=st;
}
}
out<<cnt;
return 0;
}