P1451 求细胞数量 题解

文章目录

题目描述

一矩形阵列由数字 0 0 0 到 9 9 9 组成,数字 1 1 1 到 9 9 9 代表细胞,细胞的定义为沿细胞数字上下左右若还是细胞数字则为同一细胞,求给定矩形阵列的细胞个数。

输入格式

第一行两个整数代表矩阵大小 n n n 和 m m m。

接下来 n n n 行,每行一个长度为 m m m 的只含字符 09 的字符串,代表这个 n × m n \times m n×m 的矩阵。

输出格式

一行一个整数代表细胞个数。

样例

样例输入

复制代码
4 10
0234500067
1034560500
2045600671
0000000089

样例输出

复制代码
4

数据范围与提示

对于 100 % 100\% 100% 的数据,保证 1 ≤ n , m ≤ 100 1 \le n,m \le 100 1≤n,m≤100。

题目传送门

思路及部分实现

笔者直接考虑用搜索完成此题,只需在搜索过程中把经过的每一点标记避免重复计算同一细胞即可。

  • 枚举每个点,如果当前点没有被搜索过(即没被标记过)就将计数器加一,然后从当前点展开搜索
  • 反之,如果当前点被搜索过,直接进入下一次循环,无需做特殊处理

代码实现如下:

cpp 复制代码
for(int i=1;i<=n;i++)
	for(int j=1;j<=m;j++)
		if(!fl[i][j]) cnt++,search(i,j);

笔者对于这道题更倾向于深度优先搜索 DFS \text{DFS} DFS,当然用广度优先搜索 BFS \text{BFS} BFS 也完全没问题。代码实现见完整代码。

完整代码

第一种,深度优先搜索 写法。以下代码在洛谷评测中 30 ms 30\text{ms} 30ms 通过此题。

cpp 复制代码
#include<iostream>
using namespace std;
int n,m;
bool fl[101][101];
void dfs(int x,int y){
	if(fl[x][y]||x<1||y<1||x>n||y>m) return ;
	fl[x][y]=true;
	dfs(x,y+1),dfs(x,y-1),dfs(x+1,y),dfs(x-1,y);
}
int main()
{
	int cnt=0;
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++){
			char ch;
			scanf(" %c",&ch);
			if(ch=='0') fl[i][j]=true;
		}
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
			if(!fl[i][j]) cnt++,dfs(i,j);
	printf("%d",cnt);
	return 0;
} 

第二种,广度优先搜索 写法。以下代码在洛谷评测中 34 ms 34\text{ms} 34ms 通过此题。

cpp 复制代码
#include<queue>
#include<iostream>
using namespace std;
struct node{
	int x,y;
};
int n,m;
bool fl[101][101];
void bfs(int o,int r){
	queue<node> q;
	q.push((node){o,r});
	while(!q.empty()){
		node T=q.front();q.pop();
		if(T.x<1||T.y<1||T.x>n||T.y>m||fl[T.x][T.y]) continue;
		fl[T.x][T.y]=true;
		q.push((node){T.x+1,T.y});
		q.push((node){T.x-1,T.y});
		q.push((node){T.x,T.y+1});
		q.push((node){T.x,T.y-1});
	}
}
int main()
{
	int cnt=0;
	scanf("%d%d",&n,&m);
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++){
			char ch;scanf(" %c",&ch);
			if(ch=='0') fl[i][j]=true;
		}
	for(int i=1;i<=n;i++)
		for(int j=1;j<=m;j++)
			if(!fl[i][j]) cnt++,bfs(i,j);
	printf("%d",cnt);
	return 0;
} 
相关推荐
2301_795167201 小时前
玩转Rust高级应用 如何避免对空指针做“解引用”操作,在C/C++ 里面就是未定义行为
c语言·c++·rust
智驱力人工智能2 小时前
基于视觉分析的人脸联动使用手机检测系统 智能安全管理新突破 人脸与手机行为联动检测 多模态融合人脸与手机行为分析模型
算法·安全·目标检测·计算机视觉·智能手机·视觉检测·边缘计算
2301_764441333 小时前
水星热演化核幔耦合数值模拟
python·算法·数学建模
循环过三天3 小时前
3.4、Python-集合
开发语言·笔记·python·学习·算法
priority_key5 小时前
排序算法:堆排序、快速排序、归并排序
java·后端·算法·排序算法·归并排序·堆排序·快速排序
不染尘.6 小时前
2025_11_7_刷题
开发语言·c++·vscode·算法
似水এ᭄往昔6 小时前
【C++】--stack和queue
开发语言·c++
仰望—星空6 小时前
MiniEngine学习笔记 : CommandListManager
c++·windows·笔记·学习·cg·direct3d
来荔枝一大筐7 小时前
力扣 寻找两个正序数组的中位数
算法
算法与编程之美7 小时前
理解Java finalize函数
java·开发语言·jvm·算法