2022百度之星初赛第三场--字符计数

在一张白色背景的图像上,有一些色的字符。小度发现这些字符可以分成三类:不含任何洞的字符”1”,含个洞
的字符"0”,含两个洞的字符“8”。现在, 用"示色背景,用"#" 示背景上的艷字迹,小度想问问你,
这三类字符各有多少个?
保证字符之间互不嵌套或重叠,字符的各个洞的位置不重叠,字符的每个"#"之间四联通。
格式
输入格式:第一行两个整数n(1 ≤n≤1000)和m(1≤n≤1000)。
随后n行,每行m个字符,示该该白图像。
输出格式:输出一行三个整数,分别表示”1” 的个数、"0” 的个数和"8” 的个数。
样例1
输入: 3 11
#.###. #####
#.#.#.#.#.#
#. ### . #####
输出:111

 思路:通过bfs遍历所有未被遍历且联通在一起的‘#’,并计数,将得到的数字依次除以8,0,1所需的‘#’个数,并%掉相关数字,即可得到答案;

AC代码:

#include<queue>
#include<deque>
#include<cmath>
#include<vector>
#include<sstream>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;

#define ll long long
#define PII pair<int ,int>
const int N=1010;

int n,m;
int dx[]={0,0,1,-1},dy[]={1,-1,0,0};
char mp[N][N];
bool st[N][N];
queue<PII>q;
int r1,r0,r8;

void bfs(int sx,int sy)
{
	int cnt=0;
	q.push({sx,sy});
	st[sx][sy]=1;
	while(q.size())
	{
		cnt++;
		PII t=q.front();
		q.pop();
		
		for(int i=0;i<4;i++)
		{
			int xx=t.first+dx[i],yy=t.second+dy[i];
			if(xx<0||xx>n-1||yy<0||yy>m-1)
				continue;
			if(st[xx][yy]||mp[xx][yy]=='.')
				continue;
			q.push({xx,yy});
			st[xx][yy]=1;
		}
	}
	
	r8+=cnt/13;
	cnt%=13;
	r0+=cnt/8;
	cnt%=8;
	r1+=cnt/3;
	
}

int main()
{
	scanf("%d%d",&n,&m);
	for(int i=0;i<n;i++)
		scanf("%s",mp[i]);
	
	int res=0;
	for(int i=0;i<n;i++)
		for(int j=0;j<m;j++)
			if(!st[i][j]&&mp[i][j]=='#')
				bfs(i,j);
	printf("%d %d %d\n",r1,r0,r8);
}

  • 4
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

Double.Qing

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

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

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

打赏作者

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

抵扣说明:

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

余额充值