Cod sursa(job #424000)

Utilizator GheorgheMihaiMihai Gheorghe GheorgheMihai Data 24 martie 2010 15:30:30
Problema Divk Scor 20
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.42 kb
#include<stdio.h>
int n,k,a,b,v[500002],f[100002];
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;
	}
	if(v[a]==0)
		sol--;
	for(i=a;i<=n;i++)
	{
		if(i>b)
			f[v[i-b]]--;
		f[v[i-a+1]]++;
		sol=sol+f[v[i]];
	}
	printf("%lld",sol);
	return 0;
}