【2024.2.1练习】岛屿个数(15分)

题目描述


题目思路

题目乍一看类似于“水坑个数问题”,是对陆地块进行DFS,上下左右4个方向分别对应了四种状态转移,每块陆地进行搜索后变成海洋,最终搜索次数就是岛屿个数。

但在子岛屿存在的情况下,需要先对海洋块进行DFS,由于不被岛屿包围的海洋能够通过八个方向流往地图边界,若最终没有能够流到边界,则说明这片水域是在某块岛屿内部,将水域填充成陆地,这样就能让每片大岛屿与它的所有子岛屿连成一片,消除所有子岛屿。然后再进行上述的搜索就能统计出不包含子岛屿的岛屿个数了。


我的代码

值得注意的是,一开始我的地图存储数组是int类型的,但是在输入01串的时候,本来代表地图一行的011101会被理解成一个整数,为了按位读取数据,需要将数组的类型改成char类型。

另外重要的一点,在进行DFS或BFS时必须给已经搜索过的区域进行标记,在本就储存了信息的数组里不方便再添加标记,较好的方法说建立一个相同大小的数组用于储存是否已搜索的信息。由于我的代码总共用了三次DFS:前两次搜索的方向数为8,最后一次搜索方向数为4,总共的时间复杂度约为O(20m^2n^2),很有优化的空间,不过还是通过了所有测试点。

#include <iostream>
#include <algorithm>
using namespace std;
char map[52][52];
int view[52][52];
int dfs1(int x, int y) { //判断是否连接大海view[x][y] = 1;for (int dx = -1; dx <= 1; dx++) {for (int dy = -1; dy <= 1; dy++) //8方向循环{int nx = x + dx;int ny = y + dy;if (map[nx][ny] == '2') {return 1;}if (map[nx][ny] == '0' && view[nx][ny] == 0) {if (dfs1(nx, ny)) {return 1;}}}}return 0;
}
void dfs2(int x, int y,char f) {if (view[x][y] == 1) {view[x][y] = 0;map[x][y] = f;}for (int dx = -1; dx <= 1; dx++) {for (int dy = -1; dy <= 1; dy++){int nx = x + dx;int ny = y + dy;if (view[nx][ny] == 1) {dfs2(nx, ny,f);}}}
}
void dfs3(int x, int y) {map[x][y] = '0';int dx[4] = { -1,0,0,1 };int dy[4] = { 0,-1,1,0 };for (int i = 0; i < 4; i++) //四方向{int nx = x + dx[i];int ny = y + dy[i];if (map[nx][ny] == '1') {dfs3(nx, ny);}}
}
int main() {int m;int n;int i;int j;int T;cin >> T;//输入组数while (T--) {cin >> m >> n;//赋值for (i = 1; i <= m; i++) {for (j = 1; j <= n; j++){cin >> map[i][j];view[i][j] = 0;}}//地图边界for (i = 0; i <= n+1; i++){map[0][i] = '2';map[m+1][i] = '2';}for (j = 1; j <= m+1; j++){map[j][0] = '2';map[j][n+1] = '2';}//DFS1:寻找子岛屿//DFS2:消除子岛屿for (i = 1; i <= m; i++) {for (j = 1; j <= n; j++){if (map[i][j] == '0') {if (dfs1(i, j)) { //非子岛屿dfs2(i, j, '0');}else {//子岛屿dfs2(i, j, '1');}}}}for (i = 1; i <= m; i++) {for (j = 1; j <= n; j++){if (map[i][j] == '0') {if (dfs1(i, j)) {//非子岛屿dfs2(i, j, '0');}else {//子岛屿dfs2(i, j, '1');}}}}//DFS3:统计岛屿个数int ans = 0;for (i = 1; i <= m; i++) {for (j = 1; j <= n; j++){if (map[i][j] == '1') {ans++;dfs3(i, j);}}}cout << ans<< endl;}return 0;
}

这道题连续使用了多次深度优先搜索,很有练习的价值。同时DFS算法由于其递归的性质,失之毫厘差之千里,在小心打代码的同时也要使用尽量简单的逻辑,否则容易出BUG。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/448078.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Python开源项目周排行 2024年第3周

ython 趋势周报&#xff0c;按周浏览往期 GitHub,Gitee 等最热门的Python开源项目&#xff0c;入选的项目主要参考GitHub Trending,部分参考了Gitee和其他。排名不分先后&#xff0c;都是当周相对热门的项目。 入选公式&#xff1d;70%GitHub Trending20%Gitee10%其他 关注微…

【靶场实战】Pikachu靶场敏感信息泄露关卡详解

Nx01 系统介绍 Pikachu是一个带有漏洞的Web应用系统&#xff0c;在这里包含了常见的web安全漏洞。 如果你是一个Web渗透测试学习人员且正发愁没有合适的靶场进行练习&#xff0c;那么Pikachu可能正合你意。 Nx02 敏感信息泄露概述 由于后台人员的疏忽或者不当的设计&…

【C/C++】C/C++编程——整型(二)

在 C 中&#xff0c;整型数据可以分为有符号数&#xff08;Signed&#xff09;和无符号数&#xff08;Unsigned&#xff09;&#xff0c;这两种类型主要用于表示整数值&#xff0c;但它们在表示范围和用途方面有所不同。默认情况下&#xff0c;整数类型如 int、short、long 都是…

【疑问】为什么声明和定义要分离

前言 我们在学习的时候接触过一个话&#xff1a;编写自定义函数的时候 要做到声明和定义分离 那么为什么呢 今天就来简单的了解一下 疑问&#xff1a;错误的发生 下面给出两个源文件和一个头文件以及报错信息 text.cc文件 #include"head.h"int main() {int a 1…

共用体与枚举法,链表的学习

结构体注意事项&#xff1a; 1.结构体类型可以定义在main函数里面&#xff0c;但是此时的作用域就被限定在该函数中 2.结构体的的的定义的形式&#xff1a;a.先定义类型&#xff0c;后定义变量-----struct stu s b.定义类型的同时&#xff0c;定义了变量&#xff1a;struct…

由数据插入超长引起的问题——了解GaussDB和openGauss的字符集

前言 故事是这样开始的。我们的小DEMO项目的数据库版本从openGauss 2.1.0升级到了5.0.0版本。升级后进行功能验证的时候&#xff0c;测试同学发现个BUG&#xff0c;原来通过gs_restore导出来的数据再导入时报超长&#xff0c;插入失败了&#xff0c;如下图所示&#xff0c;nva…

【GitHub项目推荐--开箱即用的直播聊天系统,高颜值,支持二次开发】【转载】

Owncast Owncast 是一个免费开源的实时视频和网络聊天服务器&#xff0c;可与现有流行的广播软件一起使用。 github源代码&#xff1a; https://github.com/owncast/owncast 国内镜像(中文) http://www.gitpp.com/samgoat/owncast-cn 项目介绍 Owncast 是一个开源的、可…

MongoDB从入门到实战之MongoDB简介

前言 相信很多同学对MongoDB这个非关系型数据库都应该挺熟悉的&#xff0c;在一些高性能、动态扩缩容、高可用、海量数据存储、数据价值较低、高扩展的业务场景下MongoDB可能是我们的首选&#xff0c;因为MongoDB通常能让我们以更低的成本解决问题&#xff08;包括学习、开发、…

1751 - 快乐的马里奥

题目 马里奥是一个快乐的油漆工人&#xff0c;这天他接到了一个油漆任务&#xff0c;要求马里奥把一个 n 行 m 列的矩阵每一格都用油漆标记一个数字&#xff0c;标记的顺序按照广度优先搜索的方式进行&#xff0c;也就是他会按照如下方式标记&#xff1a; 1、首先标记第 1 行…

消息总线在微服务中的应用

直连式配置中心 上一篇文章介绍了 Spring Cloud 中的分布式配置组件 Config&#xff0c;每个服务节点可以从Config Server 拉取外部配置信息。但是似乎还有一个悬而未决的问题&#xff0c;那就是当服务节点数量非常庞大的时候&#xff0c;我们不可能一台一台服务器挨个去手工触…

使用 Dockerfile 定制镜像详解

使用 Dockerfile 定制镜像详解 1.DockerfileFROM 指定基础镜像RUN 执行命令构建镜像 2.COPY 复制文件3.ADD 更高级的复制文件4.CMD 容器启动命令5.ENTRYPOINT 入口点6.ENV 设置环境变量7.ARG 构建参数8.VOLUME 定义匿名卷9.EXPOSE 暴露端口10.WORKDIR 指定工作目录11.USER 指定…

使用Python的Turtle模块简单绘制烟花效果

import turtle import random# 初始化屏幕 screen turtle.Screen() screen.bgcolor("black") screen.title("烟花模拟")# 创建一个Turtle来绘制烟花 firework turtle.Turtle() firework.hideturtle() firework.speed(0) # 设置绘图速度为最快# 绘制烟花…