-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathlongest-common-prefix.go
67 lines (57 loc) · 1.27 KB
/
longest-common-prefix.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
66
67
package main
import (
"fmt"
"strings"
"os"
)
func main() {
strs := []string{"flower","flow","flight"}
m := make(map[int]string)
if len(strs) == 0 {
fmt.Printf("longest common prefix : %d\n",m)
os.Exit(3)
}
a0 := strings.Split(strs[0],"")
fmt.Println()
fmt.Printf("first array : %s\n", a0)
for i:=0; i< len(a0); i++ {
elem, ok := m[i]
if ok == false {
m[i] = a0[i]
} else {
fmt.Println(elem)
continue
}
}
fmt.Printf("first lcp : %v\n", m)
for i:=1; i< len(strs); i++ {
a1 := strings.Split(strs[i],"")
fmt.Println("====================")
fmt.Printf("next array : %s\n", a1)
m = longestCommonPrefix(a1, m)
fmt.Printf("next lcp : %v\n",m)
}
arr := []string{}
for i:=0; i<len(m); i++ {
arr = append(arr, m[i])
}
fmt.Println(strings.Join(arr,""))
}
func longestCommonPrefix(a []string, m map[int]string) (map[int]string) {
m1 := make(map[int]string)
l := 0
if len(a) < len(m) {
l = len(a)
} else {
l = len(m)
}
for i:=0; i<l; i++ {
if m[i] == a[i] {
m1[i] = m[i]
continue
} else {
break
}
}
return m1
}