-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy path841.go
More file actions
48 lines (45 loc) · 1.14 KB
/
Copy path841.go
File metadata and controls
48 lines (45 loc) · 1.14 KB
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
package main
func canVisitAllRooms(rooms [][]int) bool {
visited := make(map[int]bool)
visited[0] = true
flag := false
var dfs func(int)
dfs = func(pos int) {
// fmt.Println(pos, visited, flag)
if allVisited(visited, len(rooms)) == true {
flag = true
}
for i := 0; i < len(rooms[pos]); i ++ {
if visited[rooms[pos][i]] == true {
if rooms[pos][i] == 0 {
if allVisited(visited, len(rooms)) == true {
flag = true
break
}
}
continue;
}
visited[rooms[pos][i]] = true
dfs(rooms[pos][i])
//visited[rooms[pos][i]] = false
}
}
dfs(0)
return flag
}
func allVisited(visited map[int]bool, lenght int) bool {
if len(visited) != lenght {
return false
}
hasNoVisited := false
for _, v := range visited {
if v == false {
hasNoVisited = true
break;
}
}
if hasNoVisited == false {
return true
}
return false
}