BFS专题2 矩阵中的块

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

题目:

样例:

输入

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;
}

 最后提交:

 

评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值