Cod sursa(job #1787201)

Utilizator andrei_diaconu11Andrei C. Diaconu andrei_diaconu11 Data 24 octombrie 2016 12:16:55
Problema BMatrix Scor 0
Compilator cpp Status done
Runda Arhiva de probleme Marime 2.46 kb
#include <stdio.h>
#define MAXN 200
#define INF 2000000000
int mat[MAXN+1][MAXN+1], sus[MAXN+1][1+MAXN], jos[1+MAXN][1+MAXN], dr[1+MAXN][MAXN+1], st[MAXN+1][MAXN+1];

inline int min(int a, int  b){
    return a<b ? a:b;
}

inline int max(int a, int b){
    return a>b ? a:b;
}

int main()
{
    int n, m, i, j, cr, l1, l2, min1, min2, ras;
    FILE *fi=fopen("bmatrix.in", "r"), *fo=fopen("bmatrix.out", "w");
    fscanf(fi, "%d%d", &n, &m);
    for(i=1;i<=n;i++)
        for(j=1;j<=m;j++)
            fscanf(fi, "%d", &mat[i][j]);
    //sus
    for(j=1;j<=m;j++){
        cr=0;
        for(i=1;i<=n;i++){
            if(mat[i][j]==0)
                cr++;
            else
                cr=0;
            sus[i][j]=cr;
        }
    }
    //jos
    for(j=1;j<=m;j++){
        cr=0;
        for(i=n;i>0;i--){
            if(mat[i][j]==0)
                cr++;
            else
                cr=0;
            jos[i][j]=cr;
        }
    }
    //stanga
    for(i=1;i<=n;i++){
        cr=0;
        for(j=1;j<=m;j++){
            if(mat[i][j]==0)
                cr++;
            else
                cr=0;
            st[i][j]=cr;
        }
    }
    //dreapta
    for(i=1;i<=n;i++){
        cr=0;
        for(j=m;j>0;j--){
            if(mat[i][j]==0)
                cr++;
            else
                cr=0;
            dr[i][j]=cr;
        }
    }
    //linie orizontala
    ras=0;
    for(i=1;i<n;i++){
        l1=l2=0;
        min1=min2=INF;
        for(j=1;j<=m;j++){
            if(mat[i][j]==0){
                l1++;
                min1=min(min1,sus[i][j]);
            }
            else{
                l1=0;
                min1=INF;
            }
            if(mat[i+1][j]==0){
                l2++;
                min2=min(min2,jos[i+1][j]);
            }
            else{
                l2=0;
                min2=INF;
            }
            ras=max(ras,l1*min1+l2*min2);
        }
    }
    for(j=1;j<m;j++){
        l1=l2=0;
        min1=min2=INF;
        for(i=1;i<=n;i++){
            if(mat[i][j]==0){
                l1++;
                min1=min(min1,st[i][j]);
            }
            else{
                l1=0;
                min1=INF;
            }
            if(mat[i][j+1]==0){
                l2++;
                min2=min(min2,dr[i][j+1]);
            }
            else{
                l2=0;
                min2=INF;
            }
            ras=max(ras,l1*min1+l2*min2);
        }
    }
    fprintf(fo, "%d", ras);
    fclose(fi);
    fclose(fo);
    return 0;
}