hdu1501之动态规划

题意简述:输入n,m代表n行m列,输入的只有R,F两种字符,R代表这块地方不是空闲的无法使用,F代表这个地方是空闲的可以使用,求可以使用的最大面积,这个面积一定只能是矩形面积,最后输出这个面积*3即价值。

这题是hdu1506的加强版,没看hdu1506的建议先看下。

这题思路是把每一行作为底边像hdu1506一样,然后求的这一行的最大面积,最后求的所有行的最大面积中的最大一个就是所要求的结果.


#include<iostream>
#include<cstdio>
#include<cstring>
#include<string>
#include<cstdlib>
#include<queue>
#include<algorithm>
#include<map>
#include<iomanip>
#define INF 99999999
using namespace std;

const int MAX=1001;
int hight[2][MAX];//以第i行第j列作为一块木板,每次求出以第i行为底的最大面积,最后求所有i行的最大面积中的最大一个即可. 
int Left[MAX],Right[MAX];//和hdu1056一样求最左端和最右端. 

int main(){
	int n,m,t;
	char a;
	cin>>t;
	while(t--){
	    cin>>n>>m;
		int Max=0;
		for(int i=0;i<2;++i)hight[i][m+1]=hight[i][0]=-1;
		for(int i=1;i<=m;++i)hight[0][i]=0;
		for(int i=1;i<=n;++i){
			for(int j=1;j<=m;++j){
				cin>>a;
				if(a == 'F')hight[i%2][j]=hight[(i-1)%2][j]+1;//求第i行的第j列这块木板的高度.
				else hight[i%2][j]=0;
				Left[j]=Right[j]=j; 
			}
			//就是把hdu1505变一下,看成有i个hdu1506即可,每次求面积最大值. 
			for(int j=1;j<=m;++j){//求连续的有这样高度的木板的最左端. 
				while(hight[i%2][Left[j]-1] >= hight[i%2][j])Left[j]=Left[Left[j]-1];
			}
			for(int j=m;j>=1;--j){//求连续的有这样高度的木板的最右端. 
				while(hight[i%2][Right[j]+1] >= hight[i%2][j])Right[j]=Right[Right[j]+1];
			}
			for(int j=1;j<=m;++j){
				if((Right[j]-Left[j]+1)*hight[i%2][j] > Max)Max=(Right[j]-Left[j]+1)*hight[i%2][j];
			}
		}
		cout<<Max*3<<endl;
	}
	return 0;
}




你可能感兴趣的:(hdu1501之动态规划)