Leetcode 694 Solution
This article provides solution to leetcode question 694 (number-of-distinct-islands).
Access this page by simply typing in "lcs 694" in your browser address bar if you have bunnylol configured.
Leetcode Question Link
https://leetcode.com/problems/number-of-distinct-islands
Solution
class Solution:
def numDistinctIslands(self, grid: List[List[int]]) -> int:
m = len(grid)
n = len(grid[0])
def dfs(i, j, x, y, a):
nonlocal grid
nonlocal m
nonlocal n
grid[i][j] = 2
a.append("{},{}".format(x, y))
directions = [
(1, 0),
(-1, 0),
(0, 1),
(0, -1),
]
for di, dj in directions:
neigh_i = i + di
neigh_j = j + dj
if not (0 <= neigh_i < m and 0 <= neigh_j < n):
continue
if grid[neigh_i][neigh_j] == 1:
dfs(neigh_i, neigh_j, x + di, y + dj, a)
s = set()
for i in range(m):
for j in range(n):
a = []
if grid[i][j] == 1:
dfs(i, j, 0, 0, a)
s.add(";".join(a))
return len(s)