题目 3153: 蓝桥杯 2023 年第十四届省赛真题-岛屿个数【双DFS-50行代码】

题目 3153: 蓝桥杯 2023 年第十四届省赛真题-岛屿个数

提示:👆点击标题跳转原题👆

🤔思路

  • 对八个方向进行搜索,下一步(没有走过的)只有可能是海洋或者是陆地两种情况
  • 搜到陆地就将与它相邻的陆地全部走一遍 搜索八个方向,就可以进入上下没有相邻但是斜着相邻的岛屿内部进行搜索,如果遇到环形岛屿是搜索不进去的

👏对地图的处理

  • 将地图向外扩大一格
  • 并从坐上角进行搜索

⌨️代码

c 复制代码
#include <iostream>
#include <cstring>
using namespace std;
const int N = 60;
int g[N][N];
bool st[N][N];
int dx4[] = {0, 0, 1, -1}, dy4[] = {1, -1, 0, 0};								//四个方向的向量
int dx8[] = {-1, -1, -1, 0, 1, 1, 1, 0}, dy8[] = {-1, 0, 1, 1, 1, 0, -1, -1};	//八个方向的向量
int cnt, T, m, n;

inline void dfs1(int x, int y) {
	st[x][y] = true;
	for (int i = 0; i < 4; i++) {
		int nx = x + dx4[i], ny = y + dy4[i];
		//没有走过,符合陆地的范围并且是陆地
		if (!st[nx][ny] && x >= 1 && x <= m && y >= 1 && y <= n && g[nx][ny]) dfs1(nx, ny);
	}
}

inline void dfs2(int x, int y) {		//八方向搜索
	st[x][y] = true;
	for (int i = 0; i < 8; i++) {
		int nx = x + dx8[i], ny = y + dy8[i];
		//没有走过,符合海洋的范围
		if (!st[nx][ny] && nx >=0 && nx <= m+1 && ny >= 0 && ny <= n+1) {
			if (!g[nx][ny]) dfs2(nx, ny);		//下一步是海洋继续搜索
			else if (g[nx][ny]) {				//下一步是陆地就将相邻的所有陆地设置为走过的状态
				dfs1(nx, ny);
				cnt += 1;						//并且岛屿数量加一
			}
		}
	}
}

int main() {
	ios::sync_with_stdio(false);				//取消IO同步流
	cin.tie(0);									//解除cin&cout绑定
	cin >> T;
	while (T--) {
		cin >> m >> n;
		memset(g, 0, sizeof g);					//重新分配地图
		memset(st, false, sizeof st);			//重新分配地图状态
		cnt = 0;
		for (int i = 1; i <= m; i++) {
			for (int j = 1; j <= n; j++) {
				char x;cin >> x;
				g[i][j] = x - '0';
			}
		}
		dfs2(0, 0);
		cout << cnt << endl;
	}
}

🥰通过结果

相关推荐
希望有朝一日能如愿以偿31 分钟前
力扣题解(飞机座位分配概率)
算法·leetcode·职场和发展
TANGLONG2223 小时前
【C语言】数据在内存中的存储(万字解析)
java·c语言·c++·python·考研·面试·蓝桥杯
ya888g4 小时前
蓝桥等级考试C++组17级真题-2023-05-21
开发语言·c++·蓝桥杯
SZPU领跑6 小时前
第十二届蓝桥杯嵌入式省赛程序设计题解析(基于HAL库)(第一套)
stm32·单片机·算法·职场和发展·蓝桥杯
TANGLONG2228 小时前
【C语言】字符和字符串函数(2)
java·c语言·c++·python·考研·面试·蓝桥杯
Tlog嵌入式8 小时前
蓝桥杯【物联网】零基础到国奖之路:十六. 扩展模块之矩阵按键
arm开发·stm32·单片机·mcu·物联网·蓝桥杯·iot
小迷糊糊NWCX11 小时前
【JAVA面试】关于接口
面试·职场和发展
奔跑的乌龟_12 小时前
第 17 场小白入门赛蓝桥杯
算法·蓝桥杯
叫我Cow_12 小时前
全排列和组合数区分
算法·深度优先·图论
xiao_fwuu20 小时前
LeetCode 918. 环形子数组的最大和
算法·leetcode·职场和发展