不同岛屿的数量

694 不同岛屿的数量

这道题要给出不同岛屿的数量,最直观的想法就是对发现的不同岛屿进行序列化,然后把序列化结果存到HashSet,那怎么序列化呢?

其实比较类似于二叉树的序列化,记录遍历顺序(方向),这里用

⽤ 1, 2, 3, 4 代表上下左右,⽤ -1, -2, -3, -4 代表上下左右的撤销,前序后续位置分别增加遍历顺序,即可实现序列化。

关于岛屿的相似题目:

  1. 岛屿数量 -- 二维矩阵的dfs算法
  2. 封闭岛屿数量 -- 二维矩阵的dfs算法
  3. 统计封闭岛屿的数目
  4. 统计子岛屿
  5. 不同岛屿的数量
python 复制代码
class NumDistinctIslands:
    """
    694 不同岛屿的数量
    https://leetcode.cn/problems/number-of-distinct-islands/
    """
    def solution(self, grid):
        islands = set()
        m, n = len(grid), len(grid[0])

        # 遍历grid,就是所有的封闭岛屿
        for i in range(m):
            for j in range(n):
                # 淹掉这个岛屿,同时存储岛屿的序列化结果
                if grid[i][j] == 1:
                    self.sb = ''
                    # 初始的⽅向可以随便写,不影响正确性
                    dir = 666
                    self.dfs_matrix(grid, i, j, dir)
                    islands.add(self.sb)
        return islands

    def dfs_matrix(self, grid, i, j, dir):
        m, n = len(grid), len(grid[0])

        # 跳出递归条件
        if i < 0 or i >= m or j < 0 or j >= n:
            return

        if grid[i][j] == 0:
            return

        # 前序序遍历位置:进入(i, j)
        grid[i][j] = 0
        self.sb += str(dir) + ','

        self.dfs_matrix(grid, i - 1, j, 1)  # 上
        self.dfs_matrix(grid, i + 1, j, 2)  # 下
        self.dfs_matrix(grid, i, j - 1, 3)  # 左
        self.dfs_matrix(grid, i, j + 1, 4)  # 右

        # 后序遍历位置:离开 (i, j)
        self.sb += str(-dir) + ','
相关推荐
sweetheart7-711 天前
LeetCode22. 括号生成(2024冬季每日一题 2)
算法·深度优先·力扣·dfs·左右括号匹配
sweetheart7-714 天前
LeetCode78. 子集(2024秋季每日一题 58)
二进制·dfs·枚举·数组·子集
sweetheart7-716 天前
LeetCode17. 电话号码的字母组合(2024秋季每日一题 59)
算法·深度优先·力扣·dfs
银氨溶液20 天前
力扣——113. 路径总和
数据结构·算法·leetcode·职场和发展·dfs·回溯
王老师青少年编程20 天前
CSP/信奥赛C++刷题训练:经典深搜例题(1):洛谷1605 :迷宫
c++·算法·dfs·深搜·csp·信奥赛
丶Darling.21 天前
代码随想录 | Day36 | 动态规划 :整数拆分&不同的二叉搜索树
c++·笔记·学习·算法·动态规划·dfs·记忆化搜索
C++oj1 个月前
csp普及组算法集训--Dfs
c++·学习·数学·算法·dfs
一棵星1 个月前
遍历有向图链路(DFS算法)- 优化版
java·算法·dfs·图搜索算法
Y_3_72 个月前
【回溯数独】有效的数独(medium)& 解数独(hard)
java·数据结构·windows·算法·dfs·回溯
LluckyYH2 个月前
代码随想录Day 58|拓扑排序、dijkstra算法精讲,题目:软件构建、参加科学大会
算法·深度优先·动态规划·软件构建·图论·dfs