https://vjudge.net/problem/POJ-1964
题目
AC代码
直接搜索就行
#include<stdio.h>
#include<iostream>
#include<algorithm>
#include<cstring>
#include<stdlib.h>
using namespace std;
const int N=1010;
int n,m,t,ma;
int g[N][N];
void fun(int x,int y)
{
// freopen("text.txt","w",stdout);
int h1,h2,w1,w2;
for(int i=x;i>=0;i--)
{
if(g[i][y]) h1=i;
else break;
}
for(int i=x;i<n;i++)
{
if(g[i][y]) h2=i;
else break;
}
w1=99999;
for(int i=h1;i<=h2;i++)
{
w2=0;
for(int j=y;j<m;j++)
{
if(g[i][j]) w2++;
else
break;
}
w1=min(w1,w2);
}
int h=h2-h1+1;
h=h*w1;
ma=max(ma,h);
// cout<<h1<<" "<<h2<<endl;
// cout<<ma<<endl;
}
int main()
{
scanf("%d",&t);
while(t--)
{
scanf("%d %d",&n,&m);
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
char ch;
ch=getchar();
while(ch!='R' && ch!='F') ch=getchar();
if(ch=='F') g[i][j]=1;
else if(ch=='R') g[i][j]=0;
}
}
// for(int i=0;i<n;i++)
// {
// for(int j=0;j<n;j++)
// cout<<g[i][j];
// cout<<endl;
// }
ma=0;
for(int i=0;i<n;i++)
{
for(int j=0;j<m;j++)
{
if(g[i][j])
{
fun(i,j);
// return 0;
}
}
}
cout<<ma*3;
if(t)
cout<<endl;
}
// fclose(stdout);
return 0;
}