Cod sursa(job #637081)

Utilizator loginLogin Iustin Anca login Data 20 noiembrie 2011 11:43:56
Problema DreptPal Scor 40
Compilator cpp Status done
Runda .com 2011 Marime 0.78 kb
# 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;
}