首先特判全部都是A或者全部都是B或者$n=1$的情况。

然后把矩阵四周都填充上A,枚举一个块,分以下情况讨论:

1.在它四周选两个块扩展,此时平方暴力枚举即可。

2.在它四周选定一个方向扩展两步。

3.选择一个角落,斜着扩展一步,再扩展另一步。

时间复杂度$O(n^2)$。

#include<cstdio>
#define rep(i,l,r) for(int i=l;i<=r;i++)
#define N 1010
int n,m,i,j,x,y,l,r,f[N][N],ans,t,q[10000][3],cnt;bool a[N][N];char ch[N];
struct P{int x,y,l,r,s;}s[N*N];
inline void up(int b){if(ans<b)ans=b;}
inline void add(int x,int y,int z){
if(x&&x==y)return;
q[++cnt][0]=x,q[cnt][1]=y,q[cnt][2]=z;
}
int main(){
scanf("%d",&n);gets(ch);
if(n==1)return printf("1",ans),0;
rep(i,1,n)for(gets(ch+1),j=1;j<=n;j++)if(ch[j]=='B')a[i][j]=1;
rep(i,1,n)rep(j,1,n)if(a[i][j]&&!f[i][j]){
for(x=i;a[x][j];x++);
for(y=j;a[i][y];y++);
s[++m].x=i,s[m].y=--x,s[m].l=j,s[m].r=--y;
up(s[m].s=(x-i+1)*(y-j+1));
rep(I,i,x)rep(J,j,y)f[I][J]=m;
}
if(ans==n*n)return printf("%d",ans),0;
for(i=n;~i;i--)for(j=n;~j;j--)f[i+1][j+1]=f[i][j];
for(i=1;i<=m;i++)s[i].x++,s[i].y++,s[i].l++,s[i].r++;
n+=2;
ans=2;
rep(i,1,m){
x=s[i].x,y=s[i].y,l=s[i].l,r=s[i].r,cnt=0;
if(x>2)rep(j,l,r){
if(f[x-2][j])add(f[x-2][j],0,0);
else{
t=s[i].s+2+s[f[x-2][j-1]].s+s[f[x-2][j+1]].s;
if(f[x-2][j-1]!=f[x-1][j-1])t+=s[f[x-1][j-1]].s;
if(f[x-2][j+1]!=f[x-1][j+1])t+=s[f[x-1][j+1]].s;
if(x>3)t+=s[f[x-3][j]].s;
up(t);
}
}
if(y+2<=n)rep(j,l,r){
if(f[y+2][j])add(f[y+2][j],0,0);
else{
t=s[i].s+2+s[f[y+2][j-1]].s+s[f[y+2][j+1]].s;
if(f[y+2][j-1]!=f[y+1][j-1])t+=s[f[y+1][j-1]].s;
if(f[y+2][j+1]!=f[y+1][j+1])t+=s[f[y+1][j+1]].s;
if(y+3<=n)t+=s[f[y+3][j]].s;
up(t);
}
}
if(l>2)rep(j,x,y){
if(f[j][l-2])add(f[j][l-2],0,0);
else{
t=s[i].s+2+s[f[j-1][l-2]].s+s[f[j+1][l-2]].s;
if(f[j-1][l-2]!=f[j-1][l-1])t+=s[f[j-1][l-1]].s;
if(f[j+1][l-2]!=f[j+1][l-1])t+=s[f[j+1][l-1]].s;
if(l>3)t+=s[f[j][l-3]].s;
up(t);
}
}
if(r+2<=n)rep(j,x,y){
if(f[j][r+2])add(f[j][r+2],0,0);
else{
t=s[i].s+2+s[f[j-1][r+2]].s+s[f[j+1][r+2]].s;
if(f[j-1][r+2]!=f[j-1][r+1])t+=s[f[j-1][r+1]].s;
if(f[j+1][r+2]!=f[j+1][r+1])t+=s[f[j+1][r+1]].s;
if(r+3<=n)t+=s[f[j][r+3]].s;
up(t);
}
}
if(f[x-1][l-1]){
if(x>2)add(f[x-1][l-1],f[x-2][l],0);
if(l>2)add(f[x-1][l-1],f[x][l-2],0);
}
if(f[y+1][l-1]){
if(y+2<=n)add(f[y+1][l-1],f[y+2][l],0);
if(l>2)add(f[y+1][l-1],f[y][l-2],0);
}
if(f[x-1][r+1]){
if(x>2)add(f[x-1][r+1],f[x-2][r],0);
if(r+2<=n)add(f[x-1][r+1],f[x][r+2],0);
}
if(f[y+1][r+1]){
if(y+2<=n)add(f[y+1][r+1],f[y+2][r],0);
if(r+2<=n)add(f[y+1][r+1],f[y][r+2],0);
}
if(x==y){
if(l>2)add(f[x][l-2],f[x-1][l-1],f[x+1][l-1]);
if(r+2<=n)add(f[x][r+2],f[x-1][r+1],f[x+1][r+1]);
}
if(l==r){
if(x>2)add(f[x-2][l],f[x-1][l-1],f[x-1][l+1]);
if(y+2<=n)add(f[y+2][l],f[y+1][l-1],f[y+1][l+1]);
}
up(s[i].s+2);
rep(j,1,cnt){
up(s[i].s+2+s[q[j][0]].s+s[q[j][1]].s+s[q[j][2]].s);
rep(k,j+1,cnt){
t=s[i].s+2+s[q[j][0]].s+s[q[j][1]].s+s[q[j][2]].s+s[q[k][0]].s+s[q[k][1]].s+s[q[k][2]].s;
if(q[k][0]==q[j][0]||q[k][0]==q[j][1]||q[k][0]==q[j][2])t-=s[q[k][0]].s;
if(q[k][1]==q[j][0]||q[k][1]==q[j][1]||q[k][1]==q[j][2])t-=s[q[k][1]].s;
if(q[k][2]==q[j][0]||q[k][2]==q[j][1]||q[k][2]==q[j][2])t-=s[q[k][2]].s;
up(t);
}
}
if(x>1&&l>1&&!f[x-1][l-1]){
t=s[i].s+2+s[f[x-2][l-1]].s+s[f[x-1][l-2]].s;
if(x==y&&l==r){
if(f[x-1][l-2]!=f[x][l-2])up(t+s[f[x][l-2]].s+s[f[x+1][l-1]].s);else up(t+s[f[x+1][l-1]].s);
if(f[x-2][l-1]!=f[x-2][l])up(t+s[f[x-2][l]].s+s[f[x-1][l+1]].s);else up(t+s[f[x-1][l+1]].s);
}else{
if(f[x-1][l-2]!=f[x][l-2])up(t+s[f[x][l-2]].s);
if(f[x-2][l-1]!=f[x-2][l])up(t+s[f[x-2][l]].s);
}
}
if(x>1&&r<n&&!f[x-1][r+1]){
t=s[i].s+2+s[f[x-2][r+1]].s+s[f[x-1][r+2]].s;
if(x==y&&l==r){
if(f[x-1][r+2]!=f[x][r+2])up(t+s[f[x][r+2]].s+s[f[x+1][l+1]].s);else up(t+s[f[x+1][l+1]].s);
if(f[x-2][r+1]!=f[x-2][r])up(t+s[f[x-2][r]].s+s[f[x-1][l-1]].s);else up(t+s[f[x-1][l-1]].s);
}else{
if(f[x-1][r+2]!=f[x][r+2])up(t+s[f[x][r+2]].s);
if(f[x-2][r+1]!=f[x-2][r])up(t+s[f[x-2][r]].s);
}
}
if(y<n&&l>1&&!f[y+1][l-1]){
t=s[i].s+2+s[f[y+2][l-1]].s+s[f[y+1][l-2]].s;
if(x==y&&l==r){
if(f[y+1][l-2]!=f[y][l-2])up(t+s[f[y][l-2]].s+s[f[x-1][l-1]].s);else up(t+s[f[x-1][l-1]].s);
if(f[y+2][l-1]!=f[y+2][l])up(t+s[f[y+2][l]].s+s[f[x+1][l+1]].s);else up(t+s[f[x+1][l+1]].s);
}else{
if(f[y+1][l-2]!=f[y][l-2])up(t+s[f[y][l-2]].s);
if(f[y+2][l-1]!=f[y+2][l])up(t+s[f[y+2][l]].s);
}
}
if(y<n&&r<n&&!f[y+1][r+1]){
t=s[i].s+2+s[f[y+2][r+1]].s+s[f[y+1][r+2]].s;
if(x==y&&l==r){
if(f[y+1][r+2]!=f[y][r+2])up(t+s[f[y][r+2]].s+s[f[x-1][l+1]].s);else up(t+s[f[x-1][l+1]].s);
if(f[y+2][r+1]!=f[y+2][r])up(t+s[f[y+2][r]].s+s[f[x+1][l-1]].s);else up(t+s[f[x+1][l-1]].s);
}else{
if(f[y+1][r+2]!=f[y][r+2])up(t+s[f[y][r+2]].s);
if(f[y+2][r+1]!=f[y+2][r])up(t+s[f[y+2][r]].s);
}
}
}
return printf("%d",ans),0;
}

  

BZOJ4348 : [POI2016]Park wodny的更多相关文章

  1. bzoj AC倒序

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

  2. hdu4607 Park Visit(树的直径)

    Park Visit Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total ...

  3. Codeforces Round #292 (Div. 1) C. Drazil and Park 线段树

    C. Drazil and Park 题目连接: http://codeforces.com/contest/516/problem/C Description Drazil is a monkey. ...

  4. 转:php park、unpark、ord 函数使用方法(二进制流接口应用实例)

    在工作中,我也逐渐了解到park,unpark,ord对于二进制字节处理的强大. 下面我逐一介绍它们.     park,unpark,ord这3个函数,在我们工作中,用到它们的估计不多. 我在最近一 ...

  5. Kefa and Park

    #include<bits/stdc++.h> #define max 100005 using namespace std; int cats[max]; vector<int&g ...

  6. UVALive 4221 Walk in the Park 扫描线

    Walk in the Park 题目连接: https://icpcarchive.ecs.baylor.edu/index.php?option=com_onlinejudge&Itemi ...

  7. B. Om Nom and Dark Park

    B. Om Nom and Dark Park 在满二叉树上的某些边上添加一些值.使得根节点到叶子节点的路径上的权值和都相等.求最少需要添加多少. 我们利用性质解题.   考察兄弟节点.由于他们从跟节 ...

  8. Codeforces Round #321 (Div. 2) C. Kefa and Park dfs

    C. Kefa and Park Time Limit: 1 Sec Memory Limit: 256 MB 题目连接 http://codeforces.com/contest/580/probl ...

  9. LockSupport的park和unpark

    LockSupport是JDK中比较底层的类,用来创建锁和其他同步工具类的基本线程阻塞原语. Java锁和同步器框架的核心AQS:AbstractQueuedSynchronizer,就是通过调用Lo ...

随机推荐

  1. Firefox渗透测试黑客插件集

    前天看S哥用Firefox的hackbar进行手动注入进行渗透,觉得直接运用浏览器的插件进行渗透测试有很多优点,既可以直接在前端进行注入等操作,也可以省却了寻找各种工具的麻烦.前端还是最直接的!于是这 ...

  2. maven最齐全配置pom.xml

    0001<project xmlns="http://maven.apache.org/POM/4.0.0"0002 0003xmlns:xsi="http://w ...

  3. 杭电hdoj题目分类

    HDOJ 题目分类 //分类不是绝对的 //"*" 表示好题,需要多次回味 //"?"表示结论是正确的,但还停留在模块阶 段,需要理解,证明. //简单题看到就 ...

  4. 【转】基于LDA的Topic Model变形

    转载自wentingtu 基于LDA的Topic Model变形最近几年来,随着LDA的产生和发展,涌现出了一批搞Topic Model的牛人.我主要关注了下面这位大牛和他的学生:David M. B ...

  5. Convert Sorted List to Balanced BST

    Given a singly linked list where elements are sorted in ascending order, convert it to a height bala ...

  6. html css js

    html 回顾 字体:font 属性: color: 颜色 size: 字号 表格:table 标签: tr:表格中的行 td: 单元行中的单元格 th:通常使用在table中的第一行, 成为表头, ...

  7. 【转】MySQL Temporary Table相关问题的探究

    本文转载自:http://itindex.net/detail/10901-mysql-temporary-table 问题的引入 让我们先来观察几条非常简单的MySQL语句: mysql> c ...

  8. 如何调试lua脚本

    首先感谢下ZeroBrane Studio. 这里拿cocos2dx/samples/Lua/HelloLua做例子来说明,其他的都是同样道理. 1.下载调试Lua所需的IDE,地址在这.有经济实力的 ...

  9. MYSQL集群的搭建

    按照此配置完全可以配置成功!! 一.介绍========测试环境:Server1:ndbd 192.168.1.225Server2:ndbd 192.168.1.226Server3:mysqld ...

  10. linux下常见的文件夹含义

    1./bin :获得最小的系统可操作性所需要的命令2./boot :内核和加载内核所需的文件3./dev :终端.磁盘.调制解调器等的设备项4./etc :关键的启动文件和配置文件5./home :用 ...