从上到下枚举下底边,维护$a[i]$表示$i$向上延伸多少距离里面没有坏点,$b[i]$表示$i$向上延伸多少距离里面最多只有1个坏点。

设$l0[i],r0[i]$表示以$a[i]$为最小值,往左往右能延伸到哪里,$l1[i],r1[i]$表示以$b[i]$为最小值,往左往右能延伸到哪里。

枚举$i$,有两种情况:

1.$a[i]$为最小值,那么找到$l0[i]$,将其左边的数用$b$进行替代,然后再找到前驱$L$;或者找到$r0[i]$,将其右边的数用$b$进行替代,然后再找到后继$R$。

2.$b[i]$为最小值,那么此时最优解显然是$[l1[i],r1[i]]$。

对于$L,R$的求解,可以先将所有$a$从大到小进行桶排序,建立一个双向链表,然后从大到小删除每一个,同时询问前驱与后继。

时间复杂度$O(nm)$。

#include<cstdio>
#define N 2010
int n,m,T,i,j,l0[N],r0[N],l1[N],r1[N],a[N],b[N],G[N],NXT[N],pre[N],nxt[N],L[N],R[N],ans;char s[N];
inline void add(int x,int y){NXT[y]=G[x];G[x]=y;}
inline void del(int x){pre[nxt[x]]=pre[x];nxt[pre[x]]=nxt[x];}
inline void up(int x){if(ans<x)ans=x;}
int main(){
scanf("%d%d",&n,&m);
for(i=1;i<=m;i++)l0[i]=l1[i]=1,r0[i]=r1[i]=m;
for(T=1;T<=n;T++){
scanf("%s",s+1);
for(i=j=1;i<=m;i++)if(s[i]=='.'){
a[i]++,b[i]++;
if(l0[i]<j)l0[i]=j;
if(l1[i]<j)l1[i]=j;
}else{
b[i]=a[i]+1,a[i]=0;
l1[i]=l0[i],l0[i]=1;
if(l1[i]<j)l1[i]=j;
j=i+1;
}
for(i=j=m;i;i--)if(s[i]=='.'){
if(r0[i]>j)r0[i]=j;
if(r1[i]>j)r1[i]=j;
}else{
r1[i]=r0[i],r0[i]=m;
if(r1[i]>j)r1[i]=j;
j=i-1;
}
for(i=0;i<=T;i++)G[i]=0;
for(i=m;i;i--)add(a[i],i),pre[i]=i-1,nxt[i]=i+1;
for(pre[1]=0,nxt[m]=m+1,i=T;~i;i--)for(j=G[i];j;j=NXT[j])L[j]=pre[pre[j]],del(j);
for(i=0;i<=T;i++)G[i]=0;
for(i=1;i<=m;i++)add(a[i],i),pre[i]=i-1,nxt[i]=i+1;
for(pre[1]=0,nxt[m]=m+1,i=T;~i;i--)for(j=G[i];j;j=NXT[j])R[j]=nxt[nxt[j]],del(j);
for(i=1;i<=m;i++){
up((r1[i]-l1[i]+1)*b[i]);
if(!a[i])continue;
j=l0[i];
if(j>1&&b[j-1]>=a[i])j=L[i]+1;
up((r0[i]-j+1)*a[i]);
j=r0[i];
if(j<m&&b[j+1]>=a[i])j=R[i]-1;
up((j-l0[i]+1)*a[i]);
}
}
return printf("%d",ans),0;
}

  

BZOJ3726 : PA2014Final Wykladzina的更多相关文章

  1. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

  2. bzoj 3728: PA2014Final Zarowki

    3728: PA2014Final Zarowki Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮.你可 ...

  3. 【BZOJ3728】PA2014Final Zarowki 贪心

    [BZOJ3728]PA2014Final Zarowki Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照 ...

  4. BZOJ3723 : PA2014Final Gra w podwajanie

    暴力搜索出所有可行的形状,可以发现本质不同的形状数只有6000个左右. 对于每个形状,它的大小不超过$8\times 8$,故可以按照右下角为原点重建坐标系,用一个unsigned long long ...

  5. bzoj3728: PA2014Final Zarowki

      Description 有n个房间和n盏灯,你需要在每个房间里放入一盏灯.每盏灯都有一定功率,每间房间都需要不少于一定功率的灯泡才可以完全照亮. 你可以去附近的商店换新灯泡,商店里所有正整数功率的 ...

  6. BZOJ3724 PA2014Final Krolestwo(欧拉回路+构造)

    如果没有长度为偶数的限制,新建一个点向所有奇点连边,跑欧拉回路即可,显然此时一定存在欧拉回路,因为所有点度数都为偶数. 考虑长度为偶数的限制,将每个点拆成两个点放进一个二分图里,那么每条原图中的边在二 ...

  7. 【刷题】BZOJ 3724 PA2014Final Krolestwo

    Description 你有一个无向连通图,边的总数为偶数. 设图中有k个奇点(度数为奇数的点),你需要把它们配成k/2个点对(显然k被2整除).对于每个点对(u,v),你需要用一条长度为偶数(假设每 ...

  8. @bzoj - 3724@ PA2014Final Krolestwo

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 你有一个无向连通图,边的总数为偶数. 设图中有k个奇点(度数为奇 ...

随机推荐

  1. sehll_if

    -s file 文件大小非0时为真 [ -f "somefile" ] :判断是否是一个文件[ -x "/bin/ls" ] :判断/bin/ls是否存在并有可 ...

  2. iOS中的两种主要架构及其优缺点浅析

    凡是程序的开发者,应该对程序的架构都不陌生.一个程序的架构的好坏对这个程序有着非常重要的作用.今天我们来看一下iOS开发中用要的两种主流的程序架构.这个过程中我们主要以例子的形式展开. 我们来看第一种 ...

  3. Git - 使用指南

    GIT (分布式版本控制系统) 编辑 Git是一款免费.开源的分布式版本控制系统,用于敏捷高效地处理任何或小或大的项目.[1]  Git的读音为/gɪt/. Git是一个开源的分布式版本控制系统,可以 ...

  4. 20145206《Java程序设计》实验二Java面向对象程序设计实验报告

    20145206<Java程序设计>实验二Java面向对象程序设计实验报告 实验内容 初步掌握单元测试和TDD 理解并掌握面向对象三要素:封装.继承.多态 初步掌握UML建模 熟悉S.O. ...

  5. sqlserver执行sql文件命令(sqlcmd)

    个人自用sqlcmd命令: sqlcmd -E -i test.sql -d databasename -s 127.0.0.1 sqlcmd命令解释: 用法: Sqlcmd            [ ...

  6. Linux系统监控命令及如何定位到Java线程

    >>PID.TID的区分 uid是user id,即用户id,root用户的uid是0,0为最高权限,gid是group id,用户组id,使用 id 命令可以很简单的通过用户名查看UID ...

  7. Android 5.0 如何正确启用isLoggable(一)__使用详解

    转自:http://blog.csdn.net/yihongyuelan/article/details/46409389 isLoggable是什么 在Android源码中,我们经常可以看到如下代码 ...

  8. JSON C# Class Generator ---由json字符串生成C#实体类的工具(转)

    转载地址:http://www.cnblogs.com/finesite/archive/2011/07/31/2122984.html json作为互联网上轻量便捷的数据传输格式,越来越受到重视.但 ...

  9. javascript实用技巧,js小知识

    一.js整数的操作 使用|0和~~可以将浮点转成整型且效率方面要比同类的parseInt,Math.round 要快,在处理像素及动画位移等效果的时候会很有用.性能比较见此. var foo = (1 ...

  10. 关于UltraISO打开iso文件后只有部分文件问题

    背景:在安装CentOS 7的时候,用UltraISO打开之后,只有一个EFI文件,刻完U盘,却无法引导. 之前还以为偶没下载全,就又下了一遍,还好偶搞得的NetInstall,要不然就呵呵了. 解决 ...