Pagini recente » Cod sursa (job #1362696) | Cod sursa (job #916666) | Cod sursa (job #1501194) | Cod sursa (job #448297) | Cod sursa (job #637081)
Cod sursa(job #637081)
# include <fstream>
# include <iostream>
# define DIM 1003
# define max(a,b) (a>b?a:b)
using namespace std;
int n, m, a[DIM][DIM], b[DIM][DIM], sol, v[DIM];
void read ()
{
ifstream fin ("dreptpal.in");
fin>>n>>m;
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
fin>>a[i][j];
}
void solve ()
{
int s, d;
sol=n;
for(int i=1;i<=n;++i)
for(int j=1;j<=m;++j)
{
b[j][i]=1;
s=j-1;d=j+1;
while (s && d<=m && a[i][s]==a[i][d])
--s, ++d, b[j][i]+=2;
sol=max(sol,b[j][i]);
}
int dr;
for (int i=1;i<=m;++i)
{
dr=1;
v[dr]=1;
for(int j=2;j<=n;++j)
{
while (b[i][v[dr]]>=b[i][j] && dr)--dr;
if (!dr)sol=max(sol,b[i][j]*j);
else sol=max(sol,b[i][j]*(j-v[dr]));
v[++dr]=j;
}
}
}
int main ()
{
read ();
solve ();
ofstream fout ("dreptpal.out");
fout<<sol;
}