安徽师大附中%你赛day4T2 演讲解题报告
演讲
题目背景:
众所周知,\(\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 演讲解题报告的更多相关文章
- 安徽师大附中%你赛day3T1 怜香惜玉 解题报告
怜香惜玉 题意: 已知 \(f(x)=\frac{2 \times \sum_{(i,x)=1}^x i}{φ(x)}\) 先给定数据组数\(t\)和\(k\) 每组数据给出\(n\),求\(\sum ...
- 安徽师大附中%你赛day2T3 巧克力 解题报告
巧克力 题目描述 小\(T\)有\(N\)块巧克力, 每块巧克力上都有一句话(由小写英文字母组成,不含标点) .现在每块巧克力都断成了若干截,更糟糕的是,有一些碎片丢失了 ,但是剩下的碎片之间的顺序是 ...
- 安徽师大附中%你赛day4T1 金字塔 解题报告
金字塔 题目背景: \(Zdrcl\)带着妹子们来到了胡夫金字塔周边旅游, 发现这里正在进行一个有关金字塔的游戏 题目描述: 游戏规则如下: 1. 这里的金字塔是一个 \(N\) 阶的二维金字塔. 2 ...
- 安徽师大附中%你赛day9 T2 富 解题报告
富 题目背景 出于某些原因, 苟先生在追杀富先生. 题目描述 富先生所在的地方是一个\(n\times m\)的网格,苟先生排出了他的狼狗大军,共有\(k\)条狗,第\(i\)条狗所在的位置为\((x ...
- 安徽师大附中%你赛day9 T3 贵 解题报告
贵 问题描述 苟先生的狼狗大军没有追上富先生, 所以他把它们都解雇了, 决定去雇佣一些更好的狗, 不过狗可是很贵的.苟先生有 \(w\) 元钱, 有 \(n\) 条狗可以雇佣, 第 \(i\) 条狗有 ...
- 安徽师大附中%你赛day7 T2 乘积 解题报告
乘积 题目背景 \(\mathrm{Smart}\) 最近在潜心研究数学, 他发现了一类很有趣的数字, 叫做无平方因子数. 也就是这一类数字不能够被任意一个质数的平方整除, 比如\(6\).\(7\) ...
- 安徽师大附中%你赛day6 T3 Hamsters [POI2010]CHO-Hamsters 解题报告
[POI2010]CHO-Hamsters 题意: 给出n个互不包含的字符串,要求你求出一个最短的字符串S,使得这n个字符串在S中总共至少出现m次,问S最短是多少? 范围: \(1 \le n \le ...
- 安徽师大附中%你赛day5 T3 树上行走 解题报告
树上行走 题目背景 \(\mathrm{Smart}\) 的脑洞非常大, 经常幻想出一些奇怪的东西. 题目描述 某一天,\(\mathrm{Smart}\) 幻想出了一棵没有边际的二叉树,脑补着在那棵 ...
- 模拟赛T2 交换 解题报告
模拟赛T2 交换 解题报告 题目大意: 给定一个序列和若干个区间,每次从区间中选择两个数修改使字典序最小. \(n,m\) 同阶 \(10^6\) 2.1 算法 1 按照题意模拟,枚举交换位置并比较. ...
随机推荐
- linux 用户 用户组
useradd -m -G sudo zhangxiao passwd zhangxiao
- CentOS下配置jdk
CentOS下配置jdk 1.在jdk官网上下载最新版本的jdk 2.将jdk放到相应的位置,使用如下命令来解压. .0_181 /opt/data/ tar -zxf jdk-8u181-linux ...
- 码云配置webhooks自动触发拉取代码
webhooks的使用 码云和github的钩子叫webhooks 每次您 push 代码后,都会给远程 HTTP URL 发送一个 POST 请求 码云项目管理页面的webhooks设置: http ...
- 9-C++远征之多态篇-学习笔记
C++远征之多态篇 面向对象三大特征:封装,继承,多态 多态: 发出一条命令时,不同的对象接收到同样的命令做出的动作不同 多态篇会学习到的目录: 普通虚函数 & 虚析构函数 纯虚函数:抽象类 ...
- (数据科学学习手札07)R在数据框操作上方法的总结(初级篇)
上篇我们了解了Python中pandas内封装的关于数据框的常用操作方法,而作为专为数据科学而生的一门语言,R在数据框的操作上则更为丰富精彩,本篇就R处理数据框的常用方法进行总结: 1.数据框的生成 ...
- vue2.0 Axios 的简单用法
安装 使用 npm: $ npm install axios 使用 bower: $ bower install axios 使用 cdn: <script src="https:// ...
- 12 TCP服务器 进程 线程 非阻塞
1.单进程服务器 from socket import * serSocket = socket(AF_INET, SOCK_STREAM) # 重复使用绑定的信息 serSocket.setsock ...
- LeetCode:20. Valid Parentheses(Easy)
1. 原题链接 https://leetcode.com/problems/valid-parentheses/description/ 2. 题目要求 给定一个字符串s,s只包含'(', ')', ...
- XPivot 用户手册及版本更新公示
此文仅介绍XPivot的通用功能,如有对项目中定制的高级功能感兴趣的可留言讨论 XPivot当前版本v2.2 [2015-04-20发布] v2.1 下载链接: http://pan.baidu.co ...
- 近期准备发布我的asp.net框架
此框架为超轻量级架构,适合做中小型的b/s项目