码农题,拆点BFS预处理出所有联通块的面积即可,注意分类讨论。

#include<cstdio>
#include<cmath>
using namespace std;
const double pi=acos(-1.0)/4.0;
const int N=210;
struct P{int x,y,z;P(){}P(int _x,int _y,int _z){x=_x,y=_y,z=_z;}}q[N*N*2],p;
int n,m,T,i,j,h,t,pos,c[N*N][3],v[N][N][3],a[N][N];char s[N];double sum[N*N],ans;
void add(int x,int y,int z){
if(!x||!y||x>n||y>m||v[x][y][z])return;
v[x][y][z]=pos;
c[pos][z]++;
q[++t]=P(x,y,z);
}
void bfs(int x,int y,int z){
h=1,t=0,add(x,y,z);
while(h<=t){
p=q[h++];
if(!p.z){
x=p.x-1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==3||a[x][y]==4)add(x,y,1);
if(a[x][y]==1||a[x][y]==2)add(x,y,2);
x=p.x+1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==2)add(x,y,1);
if(a[x][y]==3||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y-1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==2||a[x][y]==3)add(x,y,1);
if(a[x][y]==1||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y+1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==4)add(x,y,1);
if(a[x][y]==2||a[x][y]==3)add(x,y,2);
}
if(p.z==1){
if(a[p.x][p.y]==1){
x=p.x-1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==3||a[x][y]==4)add(x,y,1);
if(a[x][y]==1||a[x][y]==2)add(x,y,2);
x=p.x,y=p.y-1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==2||a[x][y]==3)add(x,y,1);
if(a[x][y]==1||a[x][y]==4)add(x,y,2);
}
if(a[p.x][p.y]==2){
x=p.x-1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==3||a[x][y]==4)add(x,y,1);
if(a[x][y]==1||a[x][y]==2)add(x,y,2);
x=p.x,y=p.y+1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==4)add(x,y,1);
if(a[x][y]==2||a[x][y]==3)add(x,y,2);
}
if(a[p.x][p.y]==3){
x=p.x+1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==2)add(x,y,1);
if(a[x][y]==3||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y+1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==4)add(x,y,1);
if(a[x][y]==2||a[x][y]==3)add(x,y,2);
}
if(a[p.x][p.y]==4){
x=p.x+1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==2)add(x,y,1);
if(a[x][y]==3||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y-1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==2||a[x][y]==3)add(x,y,1);
if(a[x][y]==1||a[x][y]==4)add(x,y,2);
}
}
if(p.z==2){
if(a[p.x][p.y]==1){
x=p.x+1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==2)add(x,y,1);
if(a[x][y]==3||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y+1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==4)add(x,y,1);
if(a[x][y]==2||a[x][y]==3)add(x,y,2);
}
if(a[p.x][p.y]==2){
x=p.x+1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==2)add(x,y,1);
if(a[x][y]==3||a[x][y]==4)add(x,y,2);
x=p.x,y=p.y-1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==2||a[x][y]==3)add(x,y,1);
if(a[x][y]==1||a[x][y]==4)add(x,y,2);
}
if(a[p.x][p.y]==3){
x=p.x-1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==3||a[x][y]==4)add(x,y,1);
if(a[x][y]==1||a[x][y]==2)add(x,y,2);
x=p.x,y=p.y-1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==2||a[x][y]==3)add(x,y,1);
if(a[x][y]==1||a[x][y]==4)add(x,y,2);
}
if(a[p.x][p.y]==4){
x=p.x-1,y=p.y;
if(!a[x][y])add(x,y,0);
if(a[x][y]==3||a[x][y]==4)add(x,y,1);
if(a[x][y]==1||a[x][y]==2)add(x,y,2);
x=p.x,y=p.y+1;
if(!a[x][y])add(x,y,0);
if(a[x][y]==1||a[x][y]==4)add(x,y,1);
if(a[x][y]==2||a[x][y]==3)add(x,y,2);
}
}
}
}
int main(){
scanf("%d%d",&n,&m);
for(i=1;i<=n;i++){
scanf("%s",s+1);
for(j=1;j<=m;j++)if(s[j]=='0')a[i*2-1][j*2-1]=1,a[i*2][j*2]=3;
else a[i*2-1][j*2]=2,a[i*2][j*2-1]=4;
}
n<<=1,m<<=1;
for(i=1;i<=n;i++)for(j=1;j<=m;j++){
if(!a[i][j]&&!v[i][j][0])++pos,bfs(i,j,0);
if(a[i][j]&&!v[i][j][1])++pos,bfs(i,j,1);
if(a[i][j]&&!v[i][j][2])++pos,bfs(i,j,2);
}
for(i=1;i<=pos;i++)sum[i]=c[i][0]+c[i][2]+(c[i][1]-c[i][2])*pi;
scanf("%d",&T);
while(T--){
scanf("%d%d",&i,&j);
if(a[i][j]==2||a[i][j]==4){puts("0.0000");continue;}
if(a[i][j+1]==1||a[i][j+1]==3){puts("0.0000");continue;}
if(a[i+1][j]==1||a[i+1][j]==3){puts("0.0000");continue;}
if(a[i+1][j+1]==2||a[i+1][j+1]==4){puts("0.0000");continue;}
if(!i&&!j){
if(!a[1][1])ans=sum[v[1][1][0]];
else if(a[1][1]==1)ans=sum[v[1][1][1]];
else if(a[1][1]==3)ans=sum[v[1][1][2]];
}else if(!i){
if(!a[1][j])ans=sum[v[1][j][0]];
else if(a[1][j]==2)ans=sum[v[1][j][1]];
else if(a[1][j]==4)ans=sum[v[1][j][2]];
}else if(!j){
if(!a[i][1])ans=sum[v[i][1][0]];
else if(a[i][1]==4)ans=sum[v[i][1][1]];
else if(a[i][1]==2)ans=sum[v[i][1][2]];
}else{
if(!a[i][j])ans=sum[v[i][j][0]];
else if(a[i][j]==3)ans=sum[v[i][j][1]];
else if(a[i][j]==1)ans=sum[v[i][j][2]];
}
printf("%.4f\n",ans);
}
return 0;
}

  

BZOJ3046 : lagoon的更多相关文章

  1. Cheap Hollister Clothing

    (link to hollisterco site), Spectacles don't simply take care of the eye area inside sun; Putting th ...

  2. 最有效地优化 Microsoft SQL Server 的性能

      为了最有效地优化 Microsoft SQL Server 的性能,您必须明确当情况不断变化时,性能将在哪些方面得到最大程度的改进,并集中分析这些方面.否则,在这些问题上您可能花费大量的时间和精力 ...

  3. [SinGuLaRiTy] Nescafe 24杯模拟赛

    [SinGularLaRiTy-1044] Copyright (c) SinGuLaRiTy 2017. All Rights Reserved. 小水塘(lagoon) 题目描述 忘川沧月的小水塘 ...

  4. List of CentOS Mirrors

    From:https://www.centos.org/download/mirrors/ CentOS welcomes new mirror sites. If you are consideri ...

  5. 英语发音规则---字母组合oo的发音规律

    英语发音规则---字母组合oo的发音规律 一.总结 一句话总结:在英语单词中,字母组合oo多数读长音/u:/,少数读短音/ʊ/.另外,还有极少数的特殊情况读/ʌ/, 在英语单词中,字母组合oo多数读长 ...

  6. 英语发音规则---oo

    英语发音规则---oo 一.总结 一句话总结: 1.重读音节词尾的字母组合oo发音素[u:]的音? too [tu:] adv.太;也 zoo [zu:] n.动物园 room [ru:m] n.房间 ...

  7. bzoj AC倒序

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

  8. 五、Pandas玩转数据

    Series的简单运算 import numpy as np import pandas as pd s1=pd.Series([1,2,3],index=['A','B','C']) print(s ...

  9. SFC游戏列表(维基百科)

    SFC游戏列表 日文名 中文译名 英文版名 发行日期 发行商 スーパーマリオワールド 超级马里奥世界 Super Mario World 1990年11月21日 任天堂 エフゼロ F-Zero F-Z ...

随机推荐

  1. Cocos2d坐标系转换

    Cocos2d-x坐标系和OpenGL坐标系相同,都是起源于笛卡尔坐标系(高中数学里面那种). 笛卡尔坐标系 笛卡尔坐标系中定义右手系原点在左下角,x向右,y向上,z向外,OpenGL坐标系为笛卡尔右 ...

  2. Mac 下 Chrome 浏览器 快捷键

    ⌘-Option-I 打开“开发人员工具”. ⌘-Option-J 打开“JavaScript 控制台”. ⌘-Option-U 打开当前网页的源代码. 转自: http://www.harbin-s ...

  3. java并发库 Lock 公平锁和非公平锁

    jdk1.5并发包中ReentrantLock的创建可以指定构造函数的boolean类型来得到公平锁或非公平锁,关于两者区别,java并发编程实践里面有解释 公平锁:   Threads acquir ...

  4. linux中pip安装步骤与使用详解

    pip类似RedHat里面的yum,安装软件非常方便.本节详细介绍pip的安装.以及使用方法,希望文章对各位了解pip的安装与使用带来帮助. 1.pip下载安装1.1 pip下载  代码如下 复制代码 ...

  5. Cocos2d 中的Sprite大小调整问题

    以前用UIImageView,比如  UIImageView *view = [[UIImageViewalloc] initWithImage:[UIImageimageNamed:@"b ...

  6. windows下安装Appserv等php套件之后无法进入数据库管理的问题

    在win7下安装Wamp或者Appserv后无法进入数据库管理,但是php.Apache运行全都没问题,mysql可以在命令行中管理,但是就是无法打开phpmyadmin数据库管理,点击后浏览器就显示 ...

  7. Office 2010启动时出现无法验证此应用程序的许可证的解决

    Office 2010启动之后弹出一个窗口提示:Microsoft Office无法验证此应用程序的许可证.修复尝试失败或者已被用户取消.应用程序将立即关闭. 遇到这样的情况,原因是Office的系统 ...

  8. mysql修改表的存储引擎(myisam<=>innodb)

    查看当前数据库的所支持的数据库引擎以及默认数据库引擎 mysql> show engines; +--------------------+---------+----------------- ...

  9. ubuntu下简单的驱动编译

    转自:http://www.eefocus.com/jefby1990/blog/13-02/291628_c39b8.html 本文是参考了网上多篇帖子而写的算不上什么原创.唯一值得欣慰的只不过在本 ...

  10. jquery easy ui 1.3.4 数据表格(DataGrid)(8)

    8.1.创建DataGrid html代码 <table id="dg"></table> $("#dg").datagrid({ // ...