Leetcode—200. 岛屿数量【中等】

2025每日刷题(248)

Leetcode---200. 岛屿数量

dfs实现代码

go 复制代码
func numIslands(grid [][]byte) int {
    m, n := len(grid), len(grid[0])
    ans := 0
    
    var dfs func(int, int)
    dfs = func(i int, j int) {
        if i < 0 || i >= m || j < 0 || j >= n {
            return
        }

        if grid[i][j] != '1' {
            return
        }

        grid[i][j] = 2
        dfs(i + 1, j)
        dfs(i, j - 1)
        dfs(i - 1, j)
        dfs(i, j + 1)
    }
    for i := range m {
        for j := range n {
            if grid[i][j] == '1' {
                dfs(i, j)
                ans++
            }
        }
    }
    return ans
}

运行结果

bfs实现代码

go 复制代码
type rc struct {
    row int
    column int
}

func numIslands(grid [][]byte) int {
    m, n := len(grid), len(grid[0])
    ans := 0
    directions := [][2]int{{1, 0}, {0, 1}, {-1, 0}, {0, -1}}
    bfs := func(i int, j int) {
        q := make([]rc, 0, 20)
        q = append(q, rc{i, j})
        grid[i][j] = '2'
        for i := 0; i < len(q); i++ {
            cur := q[i]
            for _, d := range directions {
                ti, tj := cur.row + d[0], cur.column + d[1]
                if ti < 0 || ti >= m || tj < 0 || tj >= n {
                    continue
                }
                if grid[ti][tj] != '1' {
                    continue
                }
                grid[ti][tj] = '2'
                q = append(q, rc{ti, tj})
            }
        }
    }

    for i := range m {
        for j := range n {
            if grid[i][j] == '1' {
                ans++
                bfs(i, j)
            }
        }
    }
    return ans
}

运行结果

之后我会持续更新,如果喜欢我的文章,请记得一键三连哦,点赞关注收藏,你的每一个赞每一份关注每一次收藏都将是我前进路上的无限动力 !!!↖(▔▽▔)↗感谢支持!

相关推荐
2501_926978331 小时前
AI的三次起落发展分析,及未来预测----理论5.0的应用
人工智能·经验分享·笔记·ai写作·agi
Zero2 小时前
机器学习微积分--(1)核心思想
人工智能·算法·机器学习
有Li3 小时前
一种病理学内容感知变速率学习图像压缩框架 (PathoLIC)/文献速递-多模态应用技术
人工智能·深度学习·算法·计算机视觉·医学生
x_xbx3 小时前
LeetCode:34. 在排序数组中查找元素的第一个和最后一个位置
数据结构·算法·leetcode
想打游戏的程序猿3 小时前
核心概念层——深入理解 Agent 是什么
后端·ai编程
Ricky_Theseus3 小时前
数据库关系代数 - 连接操作
linux·数据库·算法
绿算技术3 小时前
宝辰股份董事长莅临绿算技术调研交流
人工智能·科技·算法
码云数智-园园3 小时前
哈希冲突的解决之道:深入理解哈希表底层原理
算法·哈希算法
qq_416018724 小时前
C++中的模板方法模式
开发语言·c++·算法
woniu_maggie4 小时前
SAP Web Service日志监控:如何用SRT_UTIL快速定位接口问题
后端