Cod sursa(job #1673749)

Utilizator RG1999one shot RG1999 Data 4 aprilie 2016 09:08:27
Problema Divk Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.8 kb
#include <cstdio>
# define DIM 1000000
using namespace std;
int nr,n,k,a,b,x,s[500005],i,j;
int poz=0;
char buff[DIM];
void citire(int &numar)
{
    numar=0;
    while(buff[poz]<'0'||buff[poz]>'9')
        if(++poz==DIM)
        fread(buff,1,DIM,stdin),poz=0;
    while('0'<=buff[poz]&&buff[poz]<='9')
    {
        numar=numar*10+buff[poz]-'0';
        if(buff[++poz]==DIM)
               fread(buff,1,DIM,stdin),poz=0;
    }

}
int main(void)
{
    freopen("divk.in","r",stdin);
    freopen("divk.out","w",stdout);
    scanf("%d%d%d%d",&n,&k,&a,&b);
    for(i=1;i<=n;i++)
    {
        citire(x);
        s[i]=s[i-1]+x;
    }
    for(i=1;i<=n;i++)
        for(j=i;j<=i+b-1&&j<=n;j++)
        if((s[j]-s[i-1])%k==0&&j-i+1>=a)
            nr++;
    printf("%d",nr);
    return 0;
}