演讲

题目背景:

众所周知,\(\mathrm{Zdrcl}\)是一名天天\(\mathrm{AK}\)的高水平选手。

作为一民长者,为了向大家讲述自己\(\mathrm{AK}\)的经验,他决定在一个礼堂里为大家举办一场演讲。

这个礼堂拥有\(N\times M\)个位子,排成\(N\)行\(M\)列。每个位子都有一盏灯,一开始有的灯是亮的,有的灯是灭的。这个礼堂十分诡异,人们操作一次只能使某一行或某一列(某一行或某一列由操作者你自己来决定)的灯的明暗状态全都发生转变(显然,我们不一定可以把所有的灯都点亮)。

来听演讲的人只会坐在灯已经被点亮的位置, 所以可以听演讲的位置只会是一个只由灯是亮的的位子所组成的矩形(不然坐太乱,\(\mathrm{Zdrcl}\)会不高兴的) 。

\(\mathrm{Zdrcl}\)知道会有很多人来听演讲, 所以他希望找到一个经过若干操

作后的面积最大的只由灯是亮的的位子所组成的矩形。 这个任务当然由想\(\mathrm{AK}\)的你来完成啦!

输入输出格式

输入格式:

第一行两个正整数表示\(N,M\)。

接下来有\(N\)行,每行有\(M\)个字符(‘#’表示这个灯初始状态是亮的,‘.’表示这个灯初始状态是暗的)。

输出格式

一行一个整数表示你找到的矩形的面积。

数据范围

对于\(5\%\)的数据:\(N=2,M=2\)

对于\(15\%\)的数据:\(N\times M\le 8\)

对于\(30\%\)的数据:\(N,M\le 10\)

对于\(60\%\)的数据:\(N\le 1\le 10^2\)

对于\(80\%\)的数据:\(N\le 4\times 10^2\)

对于\(100\%\)的数据:\(N\le 2\times 10^3\)

输入文件比较大, 请使用比较快速的读入方法。

提示

这一题写起来不是很困难。


这一题确实不算难

主要就是“手玩手玩,再手玩”

如果我们的某一个矩形是答案矩形,那么它一定会满足什么呢?

假设现在我们已经做完了行操作得到了中间状态,那么中间状态如何指经过列操作得到答案矩形呢?

我们再探究探究如何只通过列操作得到中间状态呢?

手玩以后,我们发现,如果一个原始的01矩阵相邻行异或之后,每一行连续的0,1即是合法的选取

这里就转换成了一个取矩形的问题,可以使用单调栈进行优化


Code:

#include <cstdio>
#include <bitset>
using namespace std;
const int N=2010;
bitset <N> a[N],d[N];
int max(int x,int y){return x>y?x:y;}
int n,m,ans;char c;
int f[N][N],L[N],R[N],s[N],tot;
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("\n");
for(int j=1;j<=m;j++)
{
scanf("%c",&c);
if(c=='#') d[i][j-1]=1;
}
}
for(int i=2;i<=n;i++)
a[i]=d[i]^d[i-1];
for(int i=1;i<=n;i++)
{
f[i][m]=1;
for(int j=m-1;j;j--)
{
if(a[i][j-1]==a[i][j])
f[i][j]=f[i][j+1]+1;
else
f[i][j]=1;
}
}
for(int i=1;i<=m;i++)
{
tot=0;
for(int j=2;j<=n;j++)
{
L[j]=1;
while(tot&&f[s[tot]][i]>=f[j][i]) L[j]+=L[s[tot--]];
s[++tot]=j;
}
tot=0;
for(int j=n;j>1;j--)
{
R[j]=1;
while(tot&&f[s[tot]][i]>=f[j][i]) R[j]+=R[s[tot--]];
s[++tot]=j;
}
for(int j=2;j<=n;j++)
ans=max(ans,f[j][i]*(R[j]+L[j]));
}
printf("%d\n",ans);
return 0;
}

2018.8.16

安徽师大附中%你赛day4T2 演讲解题报告的更多相关文章

  1. 安徽师大附中%你赛day3T1 怜香惜玉 解题报告

    怜香惜玉 题意: 已知 \(f(x)=\frac{2 \times \sum_{(i,x)=1}^x i}{φ(x)}\) 先给定数据组数\(t\)和\(k\) 每组数据给出\(n\),求\(\sum ...

  2. 安徽师大附中%你赛day2T3 巧克力 解题报告

    巧克力 题目描述 小\(T\)有\(N\)块巧克力, 每块巧克力上都有一句话(由小写英文字母组成,不含标点) .现在每块巧克力都断成了若干截,更糟糕的是,有一些碎片丢失了 ,但是剩下的碎片之间的顺序是 ...

  3. 安徽师大附中%你赛day4T1 金字塔 解题报告

    金字塔 题目背景: \(Zdrcl\)带着妹子们来到了胡夫金字塔周边旅游, 发现这里正在进行一个有关金字塔的游戏 题目描述: 游戏规则如下: 1. 这里的金字塔是一个 \(N\) 阶的二维金字塔. 2 ...

  4. 安徽师大附中%你赛day9 T2 富 解题报告

    富 题目背景 出于某些原因, 苟先生在追杀富先生. 题目描述 富先生所在的地方是一个\(n\times m\)的网格,苟先生排出了他的狼狗大军,共有\(k\)条狗,第\(i\)条狗所在的位置为\((x ...

  5. 安徽师大附中%你赛day9 T3 贵 解题报告

    贵 问题描述 苟先生的狼狗大军没有追上富先生, 所以他把它们都解雇了, 决定去雇佣一些更好的狗, 不过狗可是很贵的.苟先生有 \(w\) 元钱, 有 \(n\) 条狗可以雇佣, 第 \(i\) 条狗有 ...

  6. 安徽师大附中%你赛day7 T2 乘积 解题报告

    乘积 题目背景 \(\mathrm{Smart}\) 最近在潜心研究数学, 他发现了一类很有趣的数字, 叫做无平方因子数. 也就是这一类数字不能够被任意一个质数的平方整除, 比如\(6\).\(7\) ...

  7. 安徽师大附中%你赛day6 T3 Hamsters [POI2010]CHO-Hamsters 解题报告

    [POI2010]CHO-Hamsters 题意: 给出n个互不包含的字符串,要求你求出一个最短的字符串S,使得这n个字符串在S中总共至少出现m次,问S最短是多少? 范围: \(1 \le n \le ...

  8. 安徽师大附中%你赛day5 T3 树上行走 解题报告

    树上行走 题目背景 \(\mathrm{Smart}\) 的脑洞非常大, 经常幻想出一些奇怪的东西. 题目描述 某一天,\(\mathrm{Smart}\) 幻想出了一棵没有边际的二叉树,脑补着在那棵 ...

  9. 模拟赛T2 交换 解题报告

    模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...

随机推荐

  1. 一个好用的C# HttpHelper类

    /// <summary> /// 类说明:HttpHelper类,用来实现Http访问,Post或者Get方式的,直接访问,带Cookie的,带证书的等方式,可以设置代理 /// 重要提 ...

  2. 开通CSDN博客的原因

                                                                          为什么要写博客? 提供持续学习的动力 例如,我为自己设限每天 ...

  3. keil5 mdk调用外部编辑器notepad++、sublime3、VSCode总结

    1.打开keil主界面,点击菜单栏Tools菜单,选择如下图所示的选项. 2.点击如下图所示的菜单上红笔标注的地方,给这个工具命名,如notepad++.sublime3.vscode等,如下图, 并 ...

  4. Node.js 学习笔记 (一) 安装配置

    Node.js 安装配置 本安装教程以Node.js v4.4.3 LTS(长期支持版本)版本为例 Window 上安装Node.js 你可以采用以下两种方式来安装. 1.Windows 安装包(.m ...

  5. ctf题目writeup(7)

    2019.2.10 过年休息归来,继续做题. bugku的web题,地址:https://ctf.bugku.com/challenges 1. http://123.206.87.240:8002/ ...

  6. MySQL server has gone away报错原因分析及解决办法

    原因1. MySQL 服务宕了 判断是否属于这个原因的方法很简单,执行以下命令,查看mysql的运行时长 $ mysql -uroot -p -e "show global status l ...

  7. HM16.0帧内预测重要函数笔记

    Void TEncSearch::estIntraPredQT   亮度块的帧内预测入口函数 Void TComPrediction::initAdiPatternChType 获取参考样本点并滤波 ...

  8. Angularjs 跨域post数据到springmvc

    先贴网上己有解决方案链接: http://www.tuicool.com/articles/umymmqY  (讲的是springmvc怎么做才可以跨域) http://my.oschina.net/ ...

  9. JS 实现AJAX封装(只限于异步)

    1.AJAX 分为异步 和 同步 请求 比如你去买一个食品,但是商店暂时没有这个食品 异步:等到商品有了再来买,这个期间我可以去做别的事: 同步:一直在这里等,什么时候商品来了,买到手了,再去做别的事 ...

  10. 使用Entity Framework出错

          在使用的过程中,写了一个例子,结果就报错说      The context cannot be used while the model is being created.      在 ...