-
Notifications
You must be signed in to change notification settings - Fork 116
/
Copy pathiterative_traversal_test.go
65 lines (56 loc) · 1.85 KB
/
iterative_traversal_test.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
60
61
62
63
64
65
package graph
import (
"slices"
"testing"
)
/*
TestIterativeTraversal tests solution(s) with the following signature and problem description:
Vertex struct {
Val int
Edges []*Vertex
}
func IterativeTraversal(graph []*Vertex) ([]int, []int)
Implement BFS and DFS on a graph without using recursion, and return the value of each vertex
as it is visited.
*/
func TestIterativeTraversal(t *testing.T) {
tests := []struct {
graph [][]int
bfs, dfs []int
}{
{[][]int{{2, 3}, {3}, {4}, {}}, []int{1, 2, 3, 4}, []int{1, 3, 4, 2}},
{[][]int{{2, 3}, {4, 5}, {}, {}, {}}, []int{1, 2, 3, 4, 5}, []int{1, 3, 2, 5, 4}},
{[][]int{{2, 3, 4}, {3}, {4}, {5}, {}}, []int{1, 2, 3, 4, 5}, []int{1, 4, 5, 3, 2}},
{[][]int{{2, 3, 4}, {3, 5}, {5}, {3, 5}, {}}, []int{1, 2, 3, 4, 5}, []int{1, 4, 5, 3, 2}},
{readmeGraphs["Figure_1_A"], []int{1, 2, 3, 4, 5}, []int{1, 4, 3, 5, 2}},
// {readmeGraphs["Figure_1_B"], []int{1, 2, 3, 4, 5}, []int{1, 4, 5, 3, 2}}, TODO as visited to avoid cycles
{readmeGraphs["Figure_1_C"], []int{1, 2, 4, 5}, []int{1, 2, 4, 5}},
}
for i, test := range tests {
bfs, dfs := IterativeTraversal(toGraph(test.graph))
if !slices.Equal(bfs, test.bfs) {
t.Fatalf("Failed BFS test case #%d. Want %#v got %#v", i, test.bfs, bfs)
}
if !slices.Equal(dfs, test.dfs) {
t.Fatalf("Failed DFS test case #%d. Want %#v got %#v", i, test.dfs, dfs)
}
}
}
// toGraph converts an adjacency formatted graph into a connected collection of graph vertices.
func toGraph(graph [][]int) []*Vertex {
graphMap := make(map[int]*Vertex)
for i := range graph {
graphMap[i+1] = newVertex(i + 1)
}
for i, v := range graph {
graphMap[i+1].Edges = make([]*Vertex, len(v))
for j, e := range v {
graphMap[i+1].Edges[j] = graphMap[e]
}
}
output := make([]*Vertex, len(graphMap))
for i := range len(graph) {
output[i] = graphMap[i+1]
}
return output
}