-
Notifications
You must be signed in to change notification settings - Fork 119
/
Copy pathtowers_of_hanoi_test.go
36 lines (31 loc) · 1.15 KB
/
towers_of_hanoi_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
package dnc
import (
"slices"
"testing"
)
/*
TestTowerOfHanoi tests solution(s) with the following signature and problem description:
func TowerOfHanoi(n, start, end int) [][2]int
Given n, number of disks, and start and end tower, return the moves it takes to move all
disks from start to end tower. The disks are stacked on top of each other with the
lightest being on top and heaviest being in the bottom. A heavier disk cannot be placed
on a lighter disk. You can move one disk at a time.
*/
func TestTowerOfHanoi(t *testing.T) {
tests := []struct {
n, start, end int
moves [][2]int
}{
{0, 1, 1, [][2]int{{1, 1}}},
{1, 1, 1, [][2]int{{1, 1}}},
{1, 1, 2, [][2]int{{1, 2}}},
{2, 1, 3, [][2]int{{1, 2}, {1, 3}, {2, 3}}},
{3, 1, 3, [][2]int{{1, 3}, {1, 2}, {3, 2}, {1, 3}, {2, 1}, {2, 3}, {1, 3}}},
{4, 1, 3, [][2]int{{1, 2}, {1, 3}, {2, 3}, {1, 2}, {3, 1}, {3, 2}, {1, 2}, {1, 3}, {2, 3}, {2, 1}, {3, 1}, {2, 3}, {1, 2}, {1, 3}, {2, 3}}},
}
for i, test := range tests {
if got := TowerOfHanoi(test.n, test.start, test.end); !slices.Equal(got, test.moves) {
t.Fatalf("Failed test case #%d. Want %#v got %#v", i, test.moves, got)
}
}
}