力扣题/图论/岛屿数量

岛屿数量

力扣原题

给你一个由 '1'(陆地)和 '0'(水)组成的的二维网格,请你计算网格中岛屿的数量。

岛屿总是被水包围,并且每座岛屿只能由水平方向和/或竖直方向上相邻的陆地连接形成。

此外,你可以假设该网格的四条边均被水包围。

  • 示例 1:

输入:grid = [

"1","1","1","1","0"\], \["1","1","0","1","0"\], \["1","1","0","0","0"\], \["0","0","0","0","0"

]

输出:1

  • 示例 2:

输入:grid = [

"1","1","0","0","0"\], \["1","1","0","0","0"\], \["0","0","1","0","0"\], \["0","0","0","1","1"

]

输出:3

javascript 复制代码
/**
     * @param {character[][]} grid
     * @return {number}
     */
var numIslands = function (grid) {
    const m = grid.length
    const n = grid[0].length
    let landCount = 0;

    function expandLand(row, col) {
        const isLand = grid[row][col]
        if (isLand !== '1') return
        grid[row][col] = '-1' // 访问过的土地,不可再访问
        if (row > 0) {
            // 上
            expandLand(row - 1, col)
        }
        if (row < m - 1) {
            // 下
            expandLand(row + 1, col)
        }
        if (col > 0) {
            // 左
            expandLand(row, col - 1)
        }
        if (col < n - 1) {
            // 右
            expandLand(row, col + 1)
        }
    }

    for (let r = 0; r < m; r++) {
        for (let c = 0; c < n; c++) {
            // 如果当前位置是陆地,则为新陆地
            const isLand = grid[r][c]
            // 访问周边陆地
            if (isLand === '1') {
                landCount += 1
                expandLand(r, c) // 扩张联通的陆地,全部置为已访问
            }
        }
    }

    return landCount
};

解题思路

遍历所有位置,首次遇到值为'1'陆地 时,此时岛屿数量+1,然后从上下左右四个方向寻找相连通的陆地,并标识为'-1'已访问状态,再寻找下一个陆地就不会重复了

相关推荐
Desirediscipline1 小时前
#define _CRT_SECURE_NO_WARNINGS 1
开发语言·数据结构·c++·算法·c#·github·visual studio
范纹杉想快点毕业1 小时前
C语言550例编程实例说明
算法
小O的算法实验室1 小时前
2026年SEVC SCI2区,面向无人机路径规划的领域专用算子进化算法,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
weixin_477271691 小时前
同人象:(两军停战谈判结盟的现场直播)马王堆帛书《周易》原文及甲骨文还原周朝生活现象《函谷门
算法·图搜索算法
nudt_qxx1 小时前
CUDA编程模型与硬件执行层级对应关系
linux·人工智能·算法
zheshiyangyang2 小时前
前端面试基础知识整理【Day-7】
前端·面试·职场和发展
猫头虎2 小时前
web开发常见问题解决方案大全:502/503 Bad Gateway/Connection reset/504 timed out/400 Bad Request/401 Unauthorized
运维·前端·nginx·http·https·gateway·openresty
m0_531237172 小时前
C语言-分支与循环语句练习2
c语言·开发语言·算法
qq_24218863322 小时前
3389端口内网转发概述
前端·经验分享·html
AIpanda8882 小时前
什么是AI销冠系统和AI提效软件系统?主要区别和应用场景是什么?
算法