forked from luliyucoordinate/Leetcode
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy path1258.go
57 lines (51 loc) · 1.29 KB
/
1258.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
var parent map[string]string
var data map[string][]string
func generateSentences(synonyms [][]string, text string) []string {
parent = make(map[string]string)
data = make(map[string][]string)
for _, it := range synonyms {
x, y := find(it[0]), find(it[1])
if x != y {
parent[x] = y
}
}
for k, _ := range parent {
fk := find(k)
if _, ok := data[fk]; !ok {
data[fk] = make([]string, 0)
}
data[fk] = append(data[fk], k)
}
txt := strings.Split(text, " ")
res := []string{""}
for _, w := range txt {
fw := find(w)
if _, ok := data[fw]; ok {
tmp := make([]string, 0)
for _, s := range res {
for _, v := range data[fw] {
tmp = append(tmp, s + " " + v)
}
}
res = tmp
} else {
for i := 0; i < len(res); i++ {
res[i] += " " + w
}
}
}
for i := 0; i < len(res); i++ {
res[i] = res[i][1:]
}
sort.Strings(res)
return res
}
func find(x string) string {
if _, ok := parent[x]; !ok {
parent[x] = x
}
if x != parent[x] {
parent[x] = find(parent[x])
}
return parent[x]
}