Cod sursa(job #501032)

Utilizator cat_red20Vasile Ioana cat_red20 Data 14 noiembrie 2010 09:29:35
Problema Teren Scor 30
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.62 kb
#include<stdio.h>
FILE *fin,*fout;
int a[301][301],x,nr,i,j,l,c,nr1,max,t,n,m;
int main(){
fin=fopen("teren.in","r");
fout=fopen("teren.out","w");
fscanf(fin,"%d %d %d",&n,&m,&x);
for(i=1;i<=n;i++){
	for(j=1;j<=m;j++){
		fscanf(fin,"%d",&a[i][j]);
		a[i][j]+=a[i][j-1];
	}
}
for(j=1;j<=m;j++){
	for(i=1;i<=n;i++){
		a[i][j]+=a[i-1][j];
	}
}
for(i=1;i<=n;i++){
	for(j=1;j<=m;j++){
		for(l=n-i;l>=0;l--){
			for(c=m-j;c>=0;c--){
				nr1=a[i+l][c+j]-a[i+l][j-1]-a[i-1][j+c];
				if(nr1<=x){break;}
			}
			if(nr1<=x){break;}
		}
		if((l+1)*(c+1)>max){max=(l+1)*(c+1);}
	}
}
fprintf(fout,"%d",max);
return 0;}