-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathunique_paths_iii.go
59 lines (49 loc) · 1009 Bytes
/
unique_paths_iii.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
package main
func uniquePathsIII(grid [][]int) int {
x, y := findStart(grid)
return helper(grid, x, y)
}
func helper(grid [][]int, x, y int) int {
if grid[x][y] == 2 {
if noZeroes(grid) {
return 1
}
return 0
}
grid[x][y] = 3
ans := 0
if x-1 >= 0 && (grid[x-1][y] == 0 || grid[x-1][y] == 2) {
ans += helper(grid, x-1, y)
}
if y-1 >= 0 && (grid[x][y-1] == 0 || grid[x][y-1] == 2) {
ans += helper(grid, x, y-1)
}
if x+1 < len(grid) && (grid[x+1][y] == 0 || grid[x+1][y] == 2) {
ans += helper(grid, x+1, y)
}
if y+1 < len(grid[0]) && (grid[x][y+1] == 0 || grid[x][y+1] == 2) {
ans += helper(grid, x, y+1)
}
grid[x][y] = 0
return ans
}
func noZeroes(grid [][]int) bool {
for _, x := range grid {
for _, v := range x {
if v == 0 {
return false
}
}
}
return true
}
func findStart(grid [][]int) (int, int) {
for x := 0; x < len(grid); x++ {
for y := 0; y < len(grid[0]); y++ {
if grid[x][y] == 1 {
return x, y
}
}
}
return -1, -1 //error
}