-
Notifications
You must be signed in to change notification settings - Fork 116
/
Copy pathword_ladder_test.go
35 lines (30 loc) · 1.19 KB
/
word_ladder_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
package graph
import "testing"
/*
TestWordLadder tests solution(s) with the following signature and problem description:
func WordLadder(start, end string, dic []string) int
Given a start word like `pop` and an end word like `car`, a dictionary of same length words
like `{"top","cop","cap","car"}` return the minimum number of transformations like 4 to get
from start to end where each transformation between two words can happen when they are
different by only one letter.
*/
func TestWordLadder(t *testing.T) {
tests := []struct {
start, end string
dic []string
minTransformations int
}{
{"foo", "bar", []string{}, 0},
{"foo", "bar", []string{"baz"}, 0},
{"a", "c", []string{"a", "b", "c"}, 1},
{"pop", "cop", []string{"tap", "top", "cop"}, 1},
{"car", "tor", []string{"cap", "tap", "top", "tar", "tor"}, 3},
{"pop", "car", []string{"top", "cop", "cap", "car"}, 4},
{"pot", "cop", []string{"rot", "rat", "fat", "fax", "tax", "tap", "top", "cop"}, 8},
}
for i, test := range tests {
if got := WordLadder(test.start, test.end, test.dic); got != test.minTransformations {
t.Fatalf("Failed test case #%d. Want %#v got %d", i, test.minTransformations, got)
}
}
}