DP【洛谷P3135】[USACO16JAN]堡哞Fort Moo
【洛谷P3135】[USACO16JAN]堡哞Fort Moo
Bessie和她的朋友Elsie正在建筑一个堡垒,与任何一个好的堡垒一样,这个需要一个强固的框架。Bessie想造一个轮廓是1m宽的空心矩形框架,这样堡垒就可以造在框架上了。
Bessie以及选了一个地点建筑堡垒,一片N*M(1<=N,M<=200)的平地。不幸的是,这个地方有一些沼泽地而不可以支撑框架。请帮助Bessie决定最大她可以用堡垒覆盖的区域(即支撑框架的区域),而且避免框架在任何一块沼泽地上。
朴素暴力用前缀和优化成\(n^4\)。
枚举两行,扫一遍m找出最左一列和最右一列,优化为\(n^3\)。
code:
#include <iostream>
#include <cstdio>
using namespace std;
const int wx=217;
inline int read(){
	int sum=0,f=1; char ch=getchar();
	while(ch<'0'||ch>'9'){if(ch=='-')f=-1; ch=getchar();}
	while(ch>='0'&&ch<='9'){sum=(sum<<1)+(sum<<3)+ch-'0'; ch=getchar();}
	return sum*f;
}
int ans,n,m;
int a[wx][wx],b[wx][wx],c[wx][wx],d[wx][wx];
char cc[wx];
void slove(int first,int second){
	int flag=0,fltot=0;
	for(int i=1;i<=m;i++){
		if(!b[first][i]||!b[second][i])continue;
		if(!b[first][i-1]||!b[second][i-1])flag=i;
		if(a[second][flag]-a[first][flag]+1!=second-first+1)flag++;
		if(a[second][i]-a[first][i]+1==second-first+1){
			ans=max(ans,(second-first+1)*(i-flag+1));
		}
	}
}
int main(){
	n=read(); m=read();
	for(int i=1;i<=n;i++){
		scanf("%s",cc+1);
		for(int j=1;j<=m;j++){
			if(cc[j]=='X')continue;
			a[i][j]=a[i-1][j]+1;
			b[i][j]=b[i][j-1]+1;
		}
	}
	for(int i=n;i>=1;i--){
		for(int j=m;j>=1;j--){
			if(!a[i][j])continue;
			c[i][j]=c[i+1][j]+1;
			d[i][j]=d[i][j+1]+1;
		}
	}
	/*
	$n^4暴力$
	for(int i=1;i<=n;i++){
		for(int j=1;j<=m;j++){
			if(!a[i][j])continue;
			for(int k=i;k<=n;k++){
				for(int l=j;l<=m;l++){
					if(!a[k][l])continue;
					if(k-i+1<=a[k][l]&&l-j+1<=b[k][l]&&k-i+1<=c[i][j]&&l-j+1<=d[i][j]){
						ans=max(ans,(k-i+1)*(l-j+1));
					}
				}
			}
		}
	}
	*/
	for(int i=1;i<=n;i++){
		for(int j=i+1;j<=n;j++){
			slove(i,j);
		}
	}
	printf("%d\n",ans);
	return 0;
}
												
											DP【洛谷P3135】[USACO16JAN]堡哞Fort Moo的更多相关文章
- 2018.08.17 洛谷P3135 [USACO16JAN]堡哞(前缀和处理)
		
传送门 有趣的前缀和. 数据范围中的n≤200" role="presentation" style="position: relative;"> ...
 - 树形DP 洛谷P2014 选课
		
洛谷P2014 选课 题目描述 在大学里每个学生,为了达到一定的学分,必须从很多课程里选择一些课程来学习,在课程里有些课程必须在某些课程之前学习,如高等数学总是在其它课程之前学习.现在有N门功课,每门 ...
 - 区间DP 洛谷P2858牛奶零食
		
题目链接 题意:你有n个货物从1-n依次排列,每天可以从两侧选一个出来卖,卖的价格是当天的天数乘该货物的初始价格,问这批货物卖完的最大价格 输入:第一行n,之后是n个货物的初始价值 这道题不能用贪心做 ...
 - P1279 字串距离  dp 洛谷
		
题目描述 设有字符串X,我们称在X的头尾及中间插入任意多个空格后构成的新字符串为X的扩展串,如字符串X为”abcbcd”,则字符串“abcb□cd”,“□a□bcbcd□”和“abcb□cd□”都是X ...
 - dp 洛谷P1977 出租车拼车  线性dp
		
题目背景 话说小 x 有一次去参加比赛,虽然学校离比赛地点不太远,但小 x 还是想坐 出租车去.大学城的出租车总是比较另类,有“拼车”一说,也就是说,你一个人 坐车去,还是一堆人一起,总共需要支付的钱 ...
 - 经典DP 洛谷p1880 石子合并
		
https://www.luogu.org/problemnew/show/P1880 题目 题目描述 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新 ...
 - [DP]洛谷P1115最大子段和
		
题目来源 https://www.luogu.org/problemnew/show/P1115 题目描述 给出一段序列,选出其中连续且非空的一段使得这段和最大. 输入输出格式 输入格式: 第一行是一 ...
 - 洛谷 P3133 [USACO16JAN]无线电联系Radio Contact
		
P3133 [USACO16JAN]无线电联系Radio Contact 题目描述 Farmer John has lost his favorite cow bell, and Bessie the ...
 - 尼克的任务 dp 洛谷1280
		
蒟蒻表示老久没看过dp题目了,,挺水的一道dp题目都没想出来,,, 首先设dp[i]表示从开始到i时间的最大空闲时间,用vector to[x] 表示从x点开始的任务结束时间,cnt[x]表示从x开始 ...
 
随机推荐
- Sass和Less、Stylus的转译和语法(1)
			
四.Sass.LESS和Stylus转译成CSSSass.LESS和Stylus源文件(除了LESS源文件在客户端下运行之外)都不能直接被浏览器直接识别,这样一来,要正常的使用这些源文 件,就需要将其 ...
 - java restful response 万能类
			
import java.util.HashMap; import java.util.Map; public class ResponseData { private final String mes ...
 - ECS Windows系统使用自带监视器查看IIS并发连接数
			
问题现象 ECS Windows系统如何查看IIS并发连接数? 解决方案 1.运行-->输入“perfmon.msc” . 2.在“系统监视器”图表区域里点击右键,然后点“添加计数器”. 3.在 ...
 - 2016.9.9《Oracle查询优化改写技巧与案例》电子工业出版社一书中的技巧
			
1.coalesce (c1,c2,c3,c4,...) 类似于nvl但可以从多个表达式中返回第一个不是null的值 2.要在where条件中引用列的别名,可以再嵌套一层查询 select * fro ...
 - VMware:Configuration file was created by a VMware product with more features than this version
			
Few days ago,I opened the Genesys demo VM by VMware Server 1.0.4 and got an error like this: "C ...
 - clang: error: linker command failed with exit code 1 (use -v to see invocation) 无法定位的问题
			
编译出现错误:linker command failed with exit code 1 找到Build settings->Linking->Other Linker Flags,将此 ...
 - 使用ffmpeg压缩视频
			
命令: ffmpeg -i 1.avi -b 64k 1-64k.avi ffmpeg下载:http://dl.pconline.com.cn/download/53703.html
 - java线程的三种实现方式
			
线程实现的三种种方式: 一个是继承Thread类,实现run()方法: 一个是实现Runnable接口,实现run()方法: 一个是实现Callable接口,实现call()方法:该方式和实现Runn ...
 - sklearn.svm.SVC参数说明
			
摘自:https://blog.csdn.net/szlcw1/article/details/52336824 本身这个函数也是基于libsvm实现的,所以在参数设置上有很多相似的地方.(PS: l ...
 - Ros学习——导航
			
1.导航框架 在总体框架图中可以看到,move_base提供了ROS导航的配置.运行.交互接口,它主要包括两个部分: (1) 全局路径规划(global planner):根据给定的目标位置 ...