Pagini recente » Cod sursa (job #3329159) | Cod sursa (job #1638673) | Cod sursa (job #3316503) | Cod sursa (job #3340829) | Cod sursa (job #3335388)
#include <fstream>
#include <cstring>
#include <stack>
#define nmax 202
using namespace std;
ifstream cin("bmatrix.in");
ofstream cout("bmatrix.out");
int n,m,dp[nmax],sol;
bool a[nmax][nmax];
char ch;
stack<pair<int,int>>s;
int solve(int ls,int cs,int lf,int cf){
int ans=0;
for(int i=cs;i<=cf;i++)
dp[i]=0;
dp[cf+1]=-1;
for(int i=ls;i<=lf;i++){
for(int j=cs;j<=cf+1;j++){
if(!a[i][j])
dp[j]++;
else
dp[j]=0;
int poz=j;
while(!s.empty()&&s.top().first>dp[j]){
ans=max(ans,s.top().first*(j-s.top().second));
poz=s.top().second;
s.pop();
}
s.push({dp[j],poz});
}
s.pop();
}
return ans;
}
signed main()
{
cin>>n>>m;
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++){
cin>>ch;
a[i][j]=ch-'0';
}
/// impartim matricea in doua zone
for(int i=1;i<n;i++)
sol=max(sol,solve(1,1,i,m)+solve(i+1,1,n,m));
for(int i=1;i<m;i++)
sol=max(sol,solve(1,1,n,i)+solve(1,i+1,n,m));
cout<<sol;
return 0;
}