Cod sursa(job #424011)

Utilizator GheorgheMihaiMihai Gheorghe GheorgheMihai Data 24 martie 2010 15:41:51
Problema Divk Scor 100
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.43 kb
#include<stdio.h>
int n,k,a,b,f[100002],v[500002];
int main()
{
	freopen("divk.in","r",stdin);
	freopen("divk.out","w",stdout);
	scanf("%d%d%d%d",&n,&k,&a,&b);
	int i;
	long long sol=0;
	for(i=1;i<=n;i++)
	{
		scanf("%d",&v[i]);
		v[i]+=v[i-1];
		v[i]%=k;
	}
	for(i=a;i<=n;i++)
	{
		if(i<=b && v[i]==0)
			sol++;
		sol=sol+f[v[i]];
		if(i>b)
			f[v[i-b]]--;
		f[v[i-a+1]]++;
	}
	printf("%lld",sol);
	return 0;
}