一个地图上有若干障碍,问允许出现一个障碍的最大子矩形为多大?

最大子矩形改编

#include<bits/stdc++.h>
using namespace std;
#define rep(i, j, k) for (int i = int(j); i <= int(k); ++ i)
#define dwn(i, j, k) for (int i = int(j); i >= int(k); -- i)
const int N = ;
int n, m, l[N][], r[N][], h[N][];
char s[N][N]; int main() {
scanf("%d%d", &n, &m);
rep(i, , n) scanf("%s", s[i] + );
int ans = ;
// 枚举障碍不在悬线上
// l[j][0]表示最左扩展(不能包含障碍),l[j][1]表示最右扩展(能包含障碍)
rep(j, , m) l[j][] = l[j][] = j, r[j][] = r[j][] = m + - j;
rep(i, , n) {
int lb0 = , lb1 = ;
rep(j, , m) {
if (s[i][j] == '.') {
h[j][] ++; ans = max(ans, h[j][]);
l[j][] = max(min(l[j][], j - lb0), min(l[j][], j - lb1));
l[j][] = min(l[j][], j - lb0);
}
else {
lb1 = lb0;
lb0 = j;
l[j][] = l[j][] = j;
h[j][] = ;
}
}
int rb0 = m + , rb1 = m + ;
dwn(j, m, ) {
if (s[i][j] == '.') {
r[j][] = max(min(r[j][], rb0 - j), min(r[j][], rb1 - j));
r[j][] = min(r[j][], rb0 - j);
ans = max(ans, (l[j][] + r[j][] - ) * h[j][]);
ans = max(ans, (l[j][] + r[j][] - ) * h[j][]);
ans = max(ans, (l[j][] + r[j][] - ) * h[j][]);
}
else {
rb1 = rb0;
rb0 = j;
r[j][] = r[j][] = m + - j;
}
}
}
// 枚举障碍在悬线上
// 这时候的l[j][0]表示没有障碍的悬线最左扩展,l[j][1]表示有障碍的悬线最左扩展
rep(j, , m) l[j][] = l[j][] = j, r[j][] = r[j][] = m + - j, h[j][] = h[j][] = ;
rep(i, , n) {
int lb = ;
rep(j, , m) {
if (s[i][j] == '.') {
h[j][] ++; h[j][] ++;
l[j][] = min(l[j][], j - lb);
l[j][] = min(l[j][], j - lb);
}
else {
l[j][] = min(l[j][], j - lb);
h[j][] = h[j][] + ; h[j][] = ;
l[j][] = j;
lb = j;
}
}
int rb = m + ;
dwn(j, m, ) {
if (s[i][j] == '.') {
r[j][] = min(r[j][], rb - j);
r[j][] = min(r[j][], rb - j);
}
else {
r[j][] = min(r[j][], rb - j);
r[j][] = m + - j;
rb = j;
}
}
rep(j, , m) {
ans = max(ans, h[j][] * (l[j][] + r[j][] - ));
}
}
cout << ans << '\n';
}
/*
4 5
#.#..
....#
..#..
....#
*/

Petrozavodsk Winter Camp, Warsaw U, 2014, A The Carpet的更多相关文章

  1. Petrozavodsk Winter Camp, Day 8, 2014, Ship

    $dp(i,j)$表示i-j这段还没运走时的状态,包括 运输了多少次,还剩多少空间 每次枚举运输左边还是右边转移 #include <bits/stdc++.h> #define rep( ...

  2. Petrozavodsk Winter Camp, Day 8, 2014, Fine Brochures

    1的个数-块的个数+多减的个数+flag 多减的只会在一个循环末尾出现 #include <bits/stdc++.h> using namespace std; #define rep( ...

  3. Petrozavodsk Winter Camp, Day 8, 2014, Second Trip

    给你一棵树,每次询问一个(a,b),问有多少有路径与a-b没有交集 找lca #include <bits/stdc++.h> using namespace std; #define r ...

  4. Petrozavodsk Winter Camp, Day 8, 2014, Mosaic

    给你三个数字a,b,c,让你用1-m的数字凑出来 结论:有2个1和2个2肯定凑不出来,然后就搜索 #include <bits/stdc++.h> using namespace std; ...

  5. Petrozavodsk Winter Camp, Day 8, 2014, Rectangle Count

    给一个n*m的格点图,问其中有多少个矩形? $ \sum_{x=1}^{nm} \sum_{ab=x} [a + b \leq n](n - a - b + 1)\sum_{cd=x} [c + d ...

  6. Petrozavodsk Winter Camp, Andrew, 2014, Dichromatic Trees

    条件: 1:每个红色节点的儿子都是黑色节点 2.每个叶子到根路径上的黑点数相等,等于某个常数,称作树的black height 求给定black height和节点数的符合条件的方案数 $black_ ...

  7. Petrozavodsk Winter Camp, Andrew, 2014, Bipartite Bicolored Graphs

    由i个点和j个点组成的二分图个数为 $3^{ij}$,减去不联通的部分得到得到由i,j个点组成的联通二分图个数 $g_{i,j} = 3_{ij} - \sum_{k=1}^i \sum_{l=0}^ ...

  8. 2018 Petrozavodsk Winter Camp, Yandex Cup

    A. Ability Draft solved by RDC 60min start, 148 min AC, 1Y 题意:两只 Dota 队伍,每队 \(n\) 个英雄,英雄一开始无技能,他们需要按 ...

  9. 2019 Petrozavodsk Winter Camp, Yandex Cup C. Diverse Singing 上下界网络流

    建图一共建四层 第一层为N个歌手 第二层为{pi,li} 第三层为{si,li} 第四层为M首歌 除了S和第一层与第三层与T之间的边为[1,INF] 其他边均为[0,1] #include<bi ...

随机推荐

  1. Django model 字段类型及选项解析---转载

    model field 类型1.AutoField() 自增的IntegerField,通常不用自己设置,若没有设置主键,Django会自动添加它为主键字段,Django会自动给每张表添加一个自增的p ...

  2. Python 字符串操作 starswitch() find() re.IGNORECASE replace() join()

    检测开头&结尾开头:startswith()url = 'http://www.python.org' url.startswith('http') >>>True 结尾:e ...

  3. 执行python解释器的两种方式

    执行python解释器的两种方式 1.交互式 python是高级语言,是解释型语言,逐行翻译,写一句翻译一句 print ('hello world') 2.命令行式 python和python解释器 ...

  4. vivo Xplay 5的Usb调试模式在哪里,打开vivo Xplay 5Usb调试模式的经验

    在我们使用安卓手机链接PC的时候,如果手机没有开启Usb调试模式,PC则无办法成功检测到我们的手机,部分app也无办法正常使用,因此我们需要找处理方法将手机的Usb调试模式开启,如下内容我们介绍viv ...

  5. python接口自动化-接口重定向和编码格式

    1.如果测试的接口重定向,那么只需添加allow_redirects=False禁止重定向就可: 2.如果请求的结果,中文出现没有解码 \xe9\x83\xad\xe7\xbf\xa0\xe6\x99 ...

  6. String<-->int

    String s = "123); int a = Integer.parseInt(s); String b = String.valueOf(a); Integer i = 100; 自 ...

  7. MTK-TP(电阻屏校准程序ts_lib移植)

    现今的项目中已经很少有使用电阻TP,但总有些奇怪的需求.如果项目中遇到需要校准电阻屏如何保证较快且较稳的调试TP呢.这里介绍使用ts_lib库来进行调试. 当然也可以使用一些常见的校准算法,采集5点, ...

  8. shell脚本-工作练习篇

    瞎扯时间 人的惰性真的很难去戒掉,每天工作下班回家后,只想瘫倒在床上,玩玩手游,刷刷抖音,甚至看看无聊至极的“爽文”,对于学习.看书啥的,完全提不起兴趣,也许正是因为如此,我才显得这么平庸而无趣吧.  ...

  9. ldap集成bitbucket

    confluence ldap配置跟jira ldap集成一样,请参考:https://www.cnblogs.com/imcati/p/9378668.html 需在 Global permissi ...

  10. 前向传播算法(Forward propagation)与反向传播算法(Back propagation)

    虽然学深度学习有一段时间了,但是对于一些算法的具体实现还是模糊不清,用了很久也不是很了解.因此特意先对深度学习中的相关基础概念做一下总结.先看看前向传播算法(Forward propagation)与 ...