当前位置: 首页 > news >正文

leetcode-200. 岛屿数量

1. 题目

leetcode题目链接
在这里插入图片描述

2. 解答

思路:

  1. 需要循环遍历每个节点;
  2. 找到陆地,基于陆地开始遍历陆地的上下左右;
  3. 数组dirm dirn就可以表示某个区域的上下左右;
  4. 标记遍历过的节点;
  5. 设计循环的退出条件;
#include <stdio.h>
#include <stdlib.h>int visited[300][300];
int dirm[] = {0, 0, 1, -1};
int dirn[] = {1, -1, 0, 0};int solve(int **data, int m, int n, int indexm, int indexn)
{if (indexm >= m || indexm < 0 || indexn >=n || indexn < 0) {return 0;}if (data[indexm][indexn] == 0 || visited[indexm][indexn] == 1) {return 0;}visited[indexm][indexn] = 1;int count = 1;for (int i = 0; i < 4; i++) {indexm += dirm[i];indexn += dirn[i];count += solve(data, m, n, indexm, indexn);}return count;}int main()
{int m, n;scanf("%d %d", &m, &n);if (m <= 0 || n < 0) return -1;int **data = malloc(sizeof(int *)*(m + 1));for (int i = 0; i < m; i++) {data[i] = malloc(sizeof(int) * (n+1));for (int j = 0; j < n; j++) {scanf("%d", &data[i][j]);visited[i][j] = 0;}}int count = 0;for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {if (visited[i][j] == 0 && data[i][j] == 1) {int result = 0;result +=solve(data, m, n, i, j);printf("小岛的大小:%d\n", result);count++;}}}printf("岛屿的个数:%d\n", count);for (int i = 0; i < m; i++) {free(data[i]);}free(data);return 0;
}

运行:

G3-3579:~/data/source/leetcode$ gcc 200.c
G3-3579:~/data/source/leetcode$ ./a.out 
4 5   
1 1 0 0 0
1 1 0 0 0
0 0 1 0 0
0 0 0 1 1
小岛的大小:4
小岛的大小:1
小岛的大小:2
岛屿的个数:3
http://www.lryc.cn/news/196628.html

相关文章:

  • python的搜索引擎系统设计与实现 计算机竞赛
  • Unity随笔:在Unity中使用多线程需要注意什么
  • SQL Select(选择) 语法
  • Python武器库开发-基础篇(二)
  • 在 CentOS 8.2 上安装 MySQL C/C++ 客户端库 libmysqlclient.so
  • 『C++ - STL』之优先级队列( priority_queue )
  • 简述什么是服务端包含(Server Side Include)?
  • 领英如何注册?2023超全面详细教程
  • Spring Cloud Gateway 使用 Redis 限流使用教程
  • Qt事件系统 day7
  • 微服务拆分的思考
  • DateUtil工具类记录
  • 可信执行环境简介:ARM 的 TrustZone
  • 【音视频流媒体】 3、ffmpeg、ffplay、ffprobe 超详细介绍
  • 解决kong部署自定义插件报 helloworld plugin is enabled but not installed
  • 动态数据源自定义SqlSessionFactoryBean时mybatis plus配置失效
  • 【Qt控件之QDialogButtonBox】概述及使用
  • IPv6知识概述 - ND协议
  • react-redux的connect函数实现
  • Vue3使用Vite创建项目
  • NCV7724DQBR2G车规级半桥电机驱动芯片-专为汽车,工业自动化应用提供完美解决方案
  • NSS [GWCTF 2019]枯燥的抽奖
  • 微信小程序会议OA系统
  • CICD:Circle CI 实现CICD
  • 竞赛 深度学习YOLO安检管制物品识别与检测 - python opencv
  • 【华为OD机试python】斗地主之顺子【2023 B卷|100分】
  • ant design DatePicker禁用之前的时间
  • C语言---预处理详解
  • 数组和对象有什么区别?
  • 顺序表(第二节)实现和解析