题目:

样例:
|
6 7 0 1 1 1 0 0 1 0 0 1 0 0 0 0 0 0 0 0 1 0 0 0 0 0 1 1 1 0 1 1 1 0 1 0 0 1 1 1 1 0 0 0 |
| 4 |
思路:
BFS宽度搜索,这里我们每碰到一个 ‘1’ 块,就遍历标记好哪些 ‘1’ 与这块相连,然后看我们碰到多少次就是多少个块,代码详解如下:
#include <iostream>
#include <queue>
#define endl '\n'
#define x first
#define y second
#define mk make_pair
using namespace std;
using PII = pair<int,int>;
const int N = 500;
int n,m; // 矩阵大小
int ans; // 最终答案块
int g[N][N]; // 矩阵数组
bool vis[N][N]; // 标记块 数组
// 坐标移动操作
int dx[4] = {1,0,-1,0};
int dy[4] = {0,1,0,-1};
// 坐标走动条件
bool isRun(int bx,int by)
{
return (bx >= 0 && bx < n && by >= 0 && by < m && g[bx][by] && !vis[bx][by]);
}
void BFS(int x,int y)
{
queue<PII>q;
q.push(mk(x,y));
while(q.size())
{
PII t = q.front();
q.pop();
// 标记当前走动的坐标
vis[t.x][t.y] = true;
// 开始走动
for(int i = 0;i < 4;++i)
{
int bx = t.x + dx[i];
int by = t.y + dy[i];
if(isRun(bx,by))
{
q.push(mk(bx,by));
}
}
}
return ;
}
int main()
{
cin >> n >> m;
for(int i = 0;i < n;++i)
{
for(int j = 0;j < m;++j)
{
cin >> g[i][j];
}
}
for(int i = 0;i < n;++i)
{
for(int j = 0;j < m;++j)
{
if(!vis[i][j] && g[i][j])
{
ans++;
BFS(i,j);
}
}
}
cout << ans << endl;
return 0;
}
最后提交:

该文介绍了一种使用BFS宽度搜索算法来计算矩阵中连通的1块的数量的方法。在遍历矩阵时,遇到每个1块,会进行标记并扩展到相邻的未访问过的1块。最后统计遇到的连通块次数即为答案。代码示例中展示了如何实现这一过程。






