Cod sursa(job #592647)

Utilizator Magnuscont cu nume gresit sau fals Magnus Data 29 mai 2011 15:55:04
Problema Teren Scor 60
Compilator cpp Status done
Runda Arhiva de probleme Marime 0.85 kb
#include <cstdio>

using namespace std;

int main()
{
    char v[301][301];
    int n,m,i,j,k,l,r,s,sol=0,x;
    freopen("teren.in","r",stdin);
    freopen("teren.out","w",stdout);
    scanf("%d %d %d\n",&n,&m,&k);
    for (i=1;i<=n;++i)
        v[i][0]=0;
    for (i=1;i<=n;++i)
        for (j=1;j<=m;++j)
        {
            scanf("%d",&x);
            v[i][j]=x+v[i][j-1];
        }
    for (i=1;i<m;++i)
        for (j=i+1;j<=m;++j)
        {
            l=0;s=0;
            for (r=1;r<=n;++r)
            {
                s+=v[r][j]-v[r][i-1];
                while (l<r&&s>k)
                {
                    ++l;
                    s-=v[l][j]-v[l][i-1];
                }
                if ((r-l)*(j-i+1)>sol)
                    sol=(r-l)*(j-i+1);
            }
        }
    printf("%d\n",sol);
    return 0;
}