力扣题/图论/岛屿数量

岛屿数量

力扣原题

给你一个由 '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'已访问状态,再寻找下一个陆地就不会重复了

相关推荐
Jasmine_llq几秒前
《B4264 [GESP202503 四级] 二阶矩阵》
线性代数·算法·矩阵·二维矩阵遍历枚举所有2×2矩阵·交叉乘积等式条件判断·输入输出快读加速·长整型防溢出计数统计
柳杉1 分钟前
我用Threejs 搓了一个 3D 中国地图设计器,开箱即用
前端·three.js·数据可视化
DJ斯特拉3 分钟前
Tlias智能学习辅助系统(前端部分)
前端·javascript·学习
码云数智-大飞4 分钟前
Go Channel 详解:并发通信的正确姿势
前端·数据库·git
蜡台12 分钟前
uni-indexed-list 之扩展组件实现城市列表带索引查询过滤功能
前端·vue.js·uniapp·uni-indexed
不知名的老吴16 分钟前
面经经验分享|算法和数据结构考察
数据结构·经验分享·算法
LaughingZhu18 分钟前
Product Hunt 每日热榜 | 2026-06-16
前端·人工智能·经验分享·chatgpt·html
snow@li20 分钟前
前端:构建工具(Vite / Webpack)的 文件指纹(File Hash) 机制 / 浏览器缓存控制
前端·webpack·哈希算法
叫我:松哥30 分钟前
基于Python flask的中学可控智能命题系统设计与实现,整合遗传算法、DeepSeek 大模型及数据库技术构建一体化应用
数据库·人工智能·python·算法·机器学习·flask·遗传算法
CoderYanger35 分钟前
A.每日一题:3612. 用特殊操作处理字符串 I
java·程序人生·leetcode·面试·职场和发展·学习方法·改行学it