T1250 The Castle(信息学奥赛一本通)

【题目描述】

一座城堡被分成m*n个方块(m≤50,n≤50),每个方块可有0~4堵墙(0表示无墙)。下面示出了建筑平面图:
在这里插入图片描述
图中的加粗黑线代表墙。几个连通的方块组成房间,房间与房间之间一定是用黑线(墙)隔开的。
现在要求你编一个程序,解决以下2个问题:
1、该城堡中有多少个房间?
2、最大的房间有多大?

【输入】

平面图用一个数字表示一个方块(第1个房间用二进制1011表示,0表示无东墙,用十进制11表示)。
第一行一个整数m(m≤50),表示房子南北方向的长度。
第二行一个整数n(n≤50),表示房子东西方向的长度。
后面的m行,每行有n个整数,每个整数都表示平面图对应位置的方块的特征。每个方块中墙的特征由数字P来描述(0≤P≤15)。数字P是下面的可能取的数字之和:
1(西墙 west)
2(北墙 north)
4(东墙 east)
8(南墙 south)
室内的墙被定义两次: 例如方块(1,1)中的南墙也被位于其南面的方块(2,1)定义了一次。
建筑中至少有两个房间。

【输出】

第1行:一个整数,表示房间总数;
第2行:一个整数,表示最大房间的面积(方块数)

【输入样例】

4
7
11 6 11 6 3 10 6
7 9 6 13 5 15 5
1 10 12 7 13 7 5
13 11 10 8 10 12 13

【输出样例】

5
9

【思路】

这道题最关键点是判断墙壁,而墙壁是用二进制表示的,因此可以考虑使用&运算符,其他的都是套模板。

【源代码】

#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<algorithm>
#include<string>
#define N 51
using namespace std;
int n,m;
int a[N][N];
int b[4]={1,2,4,8};
bool vis[N][N];
int sum,maxx;
int dir[4][2]={{0,-1},{-1,0},{0,1},{1,0}};
struct node
{
    int x;
    int y;
}q[N*100];
void bfs(int x0,int y0)
{
    int head=1,tail=1;
    int cnt=1;
    vis[x0][y0]=1;
    q[tail].x=x0;
    q[tail].y=y0;
    tail++;
    while(head<tail)
    {
        int x=q[head].x;
        int y=q[head].y;
        for(int i=0;i<4;i++)
        {
            int nx=x+dir[i][0];
            int ny=y+dir[i][1];
            if(nx>=1&&nx<=n&&ny>=1&&ny<=m&&vis[nx][ny]==0&&(a[x][y]&b[i])==0)
            {
                cnt++;
                vis[nx][ny]=1;
                q[tail].x=nx;
                q[tail].y=ny;
                tail++;
            }
        }
        head++;
    }
    if(cnt>maxx)
        maxx=cnt;
    sum++;
}
int main()
{
    memset(vis,0,sizeof(vis));
    scanf("%d%d",&n,&m);
    for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            scanf("%d",&a[i][j]);
     for(int i=1;i<=n;i++)
        for(int j=1;j<=m;j++)
            if(vis[i][j]==0)
                bfs(i,j);
    printf("%d\n%d\n",sum,maxx);
    return 0;
}
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
### 回答1: Bouncycastle官网是一个开源密码学软件库的官方网站,提供了大量关于Bouncycastle的信息,包括软件下载、文档、论坛及支持等。Bouncycastle是一个Java平台的密码学库,提供了一系列的密码学算法,包括对基本的加密和解密、数字签名、密钥交换协议、摘要算法和消息认证代码进行支持。 官网上有许多关于Bouncycastle的资讯,包括各个版本的下载、使用指南和安全警告等,用户可以过官网快速地获取最新版软件的信息。此外,官网还提供了多种语言版本的教程和实例,方便开发者们学习和使用Bouncycastle的各种功能,以及解决以上出现的一些常见问题。 最后,官网还提供了论坛,使用户能够进行交流和讨论,分享他们的经验和评论。这不仅有助于解决一些技术问题,还能提高各类开发者的技术水平和学习能力。 综上所述,Bouncycastle官网是一个提供高质量密码学库软件的官方网站,不仅提供了软件下载和支持,还提供了丰富的教程和实例供用户学习和使用,并过论坛促进用户之间的交流合作。 ### 回答2: Bouncy Castle是一个Java加密库,它具有许多加密算法,如DES,AES,RSA和DSA,以及一些安全协议和实用工具。 Bouncy Castle官网提供了关于该库的详细信息,包括使用该库进行加密和解密的示例代码以及其他相关资源。该网站还提供了下载库和API文档的链接。此外,Bouncy Castle官网还提供了用户论坛和电子邮件列表,可用于讨论该库的使用和开发。对于开发人员和安全专业人士而言,Bouncy Castle官网是一个非常有价值的资源。它为用户提供了高质量的加密库和对使用和开发该库的支持,使得开发人员能够更轻松地构建安全和可靠的应用程序。如果您是对加密感兴趣的开发人员或安全专业人士,Bouncy Castle官网将是一个不错的资源,值得您花时间来了解。 ### 回答3: Bouncy Castle是一个Java平台上的加密库,其目的是提供各种密码学算法和协议的实现。 Bouncy Castle官网提供了完整的文档和示例代码,以及非常详细的用户指南和API文档。此外,该网站还提供了对Bouncy Castle技术支持的常见问题解答。 Bouncy Castle加密库是由一个名为Legion of the Bouncy Castle的组织创建的,该组织致力于提供无偏见的密码学架构和支持。该库提供了许多加密算法和协议的实现,包括AES,RSA,DSA,ECDSA,Salsa20,Zlib,OpenPGP等等。 Bouncy Castle还提供了关于密码学相关话题的教育资源,例如密码学入门和最新的密码学新闻。如果您对密码学和安全性有兴趣,则Bouncy Castle官网是值得一看的资源。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

浅梦曾倾

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值