Pagini recente » Cod sursa (job #1812698) | Cod sursa (job #1325592) | Cod sursa (job #492516) | Cod sursa (job #226175) | Cod sursa (job #1787201)
#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;
}