开了博客之后一直没动今天水完题手痒想起这个就来水一篇陈年水题(雾

题目链接<<

  • 题意:给一张n*m个格子的地图信息,求连通块个数以及最大连通块面积.
  • 每个格子四个方向可以有墙,输入用一个十进制数表示.

把每个格子的数字展开成二进制后就表示各方向上是否有墙.

直接用结构体存每个格子,读入的时候顺便处理一下.

然后直接bfs就好啦…(QwQ我一开始写判断的时候偷懒省了大括号成功的挂掉…

然后贴一下代码(QwQ跟别人比好像写的特别长…

#include<cstdio>
#include<queue>
using namespace std;
const int N=55;
struct point{bool w[4];}map[N][N];
struct p{int x,y;};
typedef queue<p> Queue;
int n,m,tmp,ans,num;
int dx[]={0,-1,0,1};
int dy[]={-1,0,1,0};
bool vis[N][N];
Queue Q;
inline int max(int x,int y){return x>y?x:y;}
inline void decom(int x,int y,int s)
{
for(int i=0;i<4;i++)map[x][y].w[i]=s&1,s>>=1;
}
inline bool ok(int x1,int y1,int x,int y,int id)
{
if(vis[x][y])return 0;
if(x<1||y<1||x>n||y>m)return 0;
if(id==0){if(map[x1][y1].w[0]||map[x][y].w[2])return 0;}
else if(id==1){if(map[x1][y1].w[1]||map[x][y].w[3])return 0;}
else if(id==2){if(map[x1][y1].w[2]||map[x][y].w[0])return 0;}
else if(id==3){if(map[x1][y1].w[3]||map[x][y].w[1])return 0;}
return 1;
}
inline void bfs(int x,int y)
{
if(vis[x][y])return;
int temp=1;vis[x][y]=1;num++;
Q.push((p){x,y});
while(!Q.empty())
{
p t;t=Q.front();Q.pop();
for(int i=0;i<4;i++)
{
int tx=t.x+dx[i];int ty=t.y+dy[i];
if(ok(t.x,t.y,tx,ty,i))
{
vis[tx][ty]=1;temp++;
Q.push((p){tx,ty});
}
}
}ans=max(ans,temp);
}
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)scanf("%d",&tmp),decom(i,j,tmp);
for(int i=1;i<=n;i++)
for(int j=1;j<=m;j++)bfs(i,j);
printf("%d\n%d",num,ans);
return 0;
}

[IOI1994]The Castle的更多相关文章

  1. Castle Core 4.0.0 alpha001发布

    时隔一年多以后Castle 项目又开始活跃,最近刚发布了Castle Core 4.0.0 的alpha版本, https://github.com/castleproject/Core/releas ...

  2. 对Castle Windsor的Resolve方法的解析时new对象的探讨

    依赖注入框架Castle Windsor从容器里解析一个实例时(也就是调用Resolve方法),是通过调用待解析对象的构造函数new一个对象并返回,那么问题是:它是调用哪个构造函数呢? 无参的构造函数 ...

  3. AOP之Castle DynamicProxy 动态代理

    这里主要介绍使用castle这个动态代理,在.net一些开源的框架里可以找到它的影子,就连微软的rchard也是使用这个进行方法拦截等可以基于这个进行方法拦截,在这个方面PostSharp算是比较好用 ...

  4. ASP.NET Core 整合Autofac和Castle实现自动AOP拦截

    前言: 除了ASP.NETCore自带的IOC容器外,我们还可以使用其他成熟的DI框架,如Autofac,StructureMap等(笔者只用过Unity,Ninject和Castle). 1.ASP ...

  5. MVC Castle依赖注入实现代码

    1.MVc 实现依赖注入 public class WindsorControllerFactory : DefaultControllerFactory { private readonly IKe ...

  6. 避免Castle Windsor引起的内存泄露

    原文地址: http://nexussharp.wordpress.com/2012/04/21/castle-windsor-avoid-memory-leaks-by-learning-the-u ...

  7. Castle中AdditionalInterfaces用法介绍

    首先见下图(图一),其中FooController是一个没有实现任何Interface的空类.需要实现的效果是:通过FooController对象调用FooService的Do方法.设置这一不常见的场 ...

  8. Castle.ActiveRecord多数据库配置

    最近使用Castle.ActiveRecord框架,网上关于多数据支持的文章很少,因此有了这篇博文的产生. 开发工具VS2015,Sql Server2008R2 新建数据库,数据初始化脚本如下: - ...

  9. Castle Windsor常用介绍以及其在ABP项目的应用介绍

    最近在研究ABP项目,有关ABP的介绍请看阳光铭睿 博客,ABP的DI和AOP框架用的是Castle Windsor下面就对Castle Windsor项目常用方法介绍和关于ABP的使用总结 1.下载 ...

随机推荐

  1. Wasp XT合成器功能介绍

    本章节将采用图文结合的方式给大家讲解电音编曲软件FL Studio中的Wasp XT合成器的相关功能,感兴趣的朋友可以一起来交流哦. 下面我们一起来看看吧 Wasp XT是一个3振荡器合成器,它包含一 ...

  2. 什么是NTFS文件格式

    说到磁盘格式,想必大家对于NTFS格式并不陌生.我们使用的u盘等硬盘设备很多都应用了此格式.NTFS文件格式究竟是什么?它都有哪些特点?今天,小编将利用这篇文章为大家进行介绍. 一.什么是NTFS文件 ...

  3. MindManager中主题间距/线条粗细的灵活调整

    在MindManager中,主题和线条是思维导图的基本元素,只有通过它们才能将要表达的思想呈现.并联系起来.因此,关于它们的属性设置就会多一点,如颜色.宽度.位置等.而调整主题之间的距离及线条的粗细, ...

  4. 利用css3和js实现旋转木马图片小demo

    先看效果图: 上源码 html代码 <!DOCTYPE html> <html lang="en"> <head> <meta chars ...

  5. 利用perspective 和 transform 里面的几个参数来实现旋转照片墙

    旋转照片墙 首先,来看下,是什么效果吧,上效果图 ↓ 其实这个东西,很容易制作,先说下思路, 把照片都给叠在一起,然后 rotateY 旋转,给每张图片 旋转不一样的角度能构成一圈, 然后transl ...

  6. Linux(CentOS 7下httpd的安装)

    Linux(CentOS 7下httpd的安装) 自己是个linux小白.最近几天在学linux,看到视频教程中安装源码包httpd所以自己想试一试,安装过程中有很多的错误,在网上找了很久也没找到,要 ...

  7. 3. git命令行操作之远程库操作

    3.1 基本操作 注册GitHub账号 在本地创建一个本地库并初始化 登录到gitHub创建一个远程库 注意:windows的凭据管理器中会保存github登录信息.如果要切换登录者,先删除相应凭据 ...

  8. Codeforces Round #667 (Div. 3) B、C、D、E 题解

    抱歉B.C题咕了这么久 B. Minimum Product #枚举 #贪心 题目链接 题意 给定四个整数\(a, b, x, y\),其中\(a\geq x, b\geq y\),你可以执行不超过\ ...

  9. MySQL查询练习2

    MySQL查询练习2 导读: 本次MySQL的查询语句是本人考试题目: 所有题目都已通过: 该查询练习并没有sql文件进行检查: 如果有书写以及其他错误欢迎指出. 题目正文: 1.找出借书超过5本的借 ...

  10. Kubernetes-20:日志聚合分析系统—Loki的搭建与使用

    日志聚合分析系统--Loki 什么是Loki? Loki 是 Grafana Labs 团队最新的开源项目,是一个水平可扩展,高可用性,多租户的日志聚合系统.它的设计非常经济高效且易于操作,因为它不会 ...